Sie sind hier:
Wissen
Telefon (Mo-Fr 9 bis 16 Uhr):
0201/649590-0
|
Kontaktformular
MENU
Medien
Übersicht
Lexikon/Glossar
Spickzettel
Weblog
Konferenzvorträge
Fachbücher
Fachartikel
Leserportal
Autoren gesucht!
Literaturtipps
Praxisnahe Fallbeispiele
Downloads
Newsletter
.NET
Startseite
.NET 8.0
.NET 7.0
.NET 6.0
.NET 5.0
.NET Core
.NET 4.0/4.5.x/4.6.x
.NET 3.0/3.5
.NET 2.0
.NET-Lexikon
Programmiersprachen
Entwicklerwerkzeuge
Klassenreferenz
Softwarekomponenten
Windows Runtime
World Wide Wings-Demo
Versionsgeschichte
Codebeispiele
ASP.NET
Artikel
Bücher
Schulung & Beratung
Konferenzen/Events
ASP.NET
Startseite
Lexikon
Sicherheit
Konfiguration
Global.asax
Tracing
Technische Beiträge
Klassenreferenz
Programmiersprachen
Entwicklerwerkzeuge
Softwarekomponenten
Forum
Schulung & Beratung
PowerShell
Startseite
Commandlet-Referenz
Codebeispiele
Commandlet Extensions
Versionsgeschichte
Schulungen+Beratung
Windows
Startseite
Windows Runtime (WinRT)
Windows PowerShell
Windows Scripting
Windows-Schulungen
Windows-Lexikon
Windows-Forum
Scripting
Startseite
Lexikon
FAQ
Bücher
Architektur
Skriptsprachen
Scripting-Hosts
Scripting-Komponenten
COM/DCOM/COM+
ADSI
WMI
WMI-Klassenreferenz
Scripting-Tools
WSH-Editoren
Codebeispiele
.NET-Scripting
Forum
Schulung & Beratung
Nutzer
Anmeldung/Login
Buchleser-Registrierung
Gast-Registrierung
Hilfe
Website-FAQ
Technischer Support
Site Map
Tag Cloud
Suche
Kontakt
Erklärung des Begriffs: Entity Framework Core 9.0
Zur Stichwortliste unseres Lexikons
Was ist
Entity Framework Core 9.0
?
Entity Framework Core 9.0 ist der Nachfolger von
Entity Framework Core 8.0
.
Geplanter Erscheinungstermin: November 2024
Versionsgeschichte inkl. Vorabversionen
Preview 1 am 13.2.2024
Preview 2 am 12.3.2024
Preview 3 am 11.4.2024
Verbesserungen bei der Schemaerstellung
Die Umwandlung einer normalen Tabelle in eine temporäre Tabelle ist nun mit einer stark verkürzten Befehlsfolge in den Schemamigrationen möglich, siehe
https://learn.microsoft.com/en-us/ef/core/what-is-new/ef-core-9.0/whatsnew
Bei der Erstellung von Autowerten mit Sequenzen kann nun
Caching
via UseCache() und UseNoCache() konfiguriert werden, z.B.
modelBuilder.HasSequence<int>("NameDerSequence")
.HasMin(10).HasMax(255000)
.IsCyclic()
.StartsAt(11).IncrementsBy(2)
.UseCache(3);
Bei Schlüssel- und Indexspalten können nun für den
Microsoft SQL Server
Angaben zum Füll-Faktor gemacht werden. Der Füll-Faktor bestimmt den Prozentsatz des Platzes auf eine Seite in der Datenbankdatei, der mit Daten gefüllt werden soll, wobei der Rest auf jeder Seite als freier Platz für zukünftiges Wachstum reserviert wird. Der Füll-Faktor kann nun in Entity Framework Core 9.0 via HasFillFaktor() gesetzt werden für einfache und zusammengesetzte Schlüsselspalten und Indexe:
modelBuilder.Entity<User>()
.HasKey(e => e.Id)
.HasFillFactor(80);
modelBuilder.Entity<User>()
.HasAlternateKey(e => new { e.Region, e.Ssn })
.HasFillFactor(80);
modelBuilder.Entity<User>()
.HasIndex(e => new { e.Name })
.HasFillFactor(80);
modelBuilder.Entity<User>()
.HasIndex(e => new { e.Region, e.Tag })
.HasFillFactor(80);
Bei der Übersetzung von
LINQ
zu SQL fasst Entity Framework Core 9.0 nun die SQL-Befehle von verschachtelten
LINQ
-Abfragen zusammen. Während in Version 8.0 des
Objekt
-Relationalen-Mappers aus diesen beiden verschachtelten
LINQ
-Befehlen
var dotnetPosts = context
.Posts
.Where(p => p.Title.Contains(".NET"));
var results = dotnetPosts
.Where(p => p.Id > 2)
.Select(p => new { Post = p, TotalCount = dotnetPosts.Count() })
.Skip(2).Take(10)
.ToArray();
zwei SQL-Befehle zum
Datenbankmanagementsystem
gesendet wurden
SELECT COUNT(*)
FROM [Posts] AS [p]
WHERE [p].[Title] LIKE N'%.NET%'
SELECT [p].[Id], [p].[Archived], [p].[AuthorId], [p].[BlogId], [p].[Content], [p].[Discriminator], [p].[PublishedOn], [p].[Title], [p].[PromoText], [p].[Metadata]
FROM [Posts] AS [p]
WHERE [p].[Title] LIKE N'%.NET%' AND [p].[Id] > 2
ORDER BY (SELECT 1)
OFFSET @
_p_1 ROWS FETCH NEXT @__p
2 ROWS ONLY
entsteht nun in Version 9.0 nur noch diese eine SQL-Befehl:
SELECT [p].[Id], [p].[Archived], [p].[AuthorId], [p].[BlogId], [p].[Content], [p].[Discriminator], [p].[PublishedOn], [p].[Title], [p].[PromoText], [p].[Metadata], (
SELECT COUNT(*)
FROM [Posts] AS [p0]
WHERE [p0].[Title] LIKE N'%.NET%')
FROM [Posts] AS [p]
WHERE [p].[Title] LIKE N'%.NET%' AND [p].[Id] > 2
ORDER BY (SELECT 1)
OFFSET @
_p_0 ROWS FETCH NEXT @__p
1 ROWS ONLY
Verbesserungen bei der Übersetzung von
LINQ
nach SQL
Der
Objekt
-Relationale Mapper Entity Framework Core hat in Version 9.0 Verbesserungen bei der Übersetzung von
LINQ
nach SQL implementiert. Bei der Übersetzung von Abfragen, die sich auf
JSON
-Spalten beziehen, werden nun bei OPEN
JSON
…
WIT
H keine nicht für die Bedingung oder das Resultset notwendigen Teile der
JSON
-Zeichenkette ausgewertet. Wenn das Zieldatenbanksystem ein
Microsoft SQL Server
in der neusten Version 2022 ist, nutzt Entity Framework Core 9.0 nun die dort neu eingeführten T-SQL-Funktionen LEAST() und GREATEST() bei der Übersetzung von Math.Min() und Math.Max().
Mit den .NET-Funktionen EF.Parameter() und EF.Constant() können Entwicklerinnen und Entwickler nun erzwingen, dass bei der Übersetzung von
LINQ
nach SQL ein Wert in der SQL-Abfrage als Parameter bzw. als Konstante übergeben wird. Bisher lag die Entscheidung für die Parametrisierung allein beim
Objekt
-Relationalen Mapper. Nun ist dies beeinflussbar in Hinblick auf die Optimierung der Nutzung des Query Cache des
Datenbankmanagementsystem
s. EF.Constant() ist auch als ein Nachtrag zu
.NET 8.0
verfügbar, der in Version 8.0.2 erschienen ist. Dies ist ungewöhnlich, da Microsoft behauptet, bei dem modernen .NET dem Semantic Versioning
https://semver.org/lang/de/
zu folgen, das bei neuen Funktionen neue Änderung der Versionsnummer an der zweiten Stelle vorsieht.
Die
Methode
ExecuteUpdate() bietet nun eine verkürzte Syntax in Verbindung mit komplexen Typen:
var newAddress = new Address("www.IT-Visions.de", 45257, "Essen");
await
context.Stores
.Where(e => e.Region == "Germany")
.ExecuteUpdateAsync(s => s.Set
Property
(b => b.ShippingAddress, newAddress));
LINQ
- und
API
-Erweiterungen
Analog zur bereits in
Entity Framework Core 2.0
eingeführten Materialisierungs-
Methode
To
Hash
Set() gibt es nun ein asynchrones Pendant: To
Hash
SetAsync()
In
Entity Framework Core 8.0
, erschienen im November 2023, hat Microsoft die Unterstützung für den Microsoft-SQL-Server-Datentyp hierarchyid eingeführt, in Form der .NET-Klasse HierarchyId. Seit Version 9.0 Preview 3 können Entwicklerinnen und Entwickler HierarchyId-Instanzen nicht nur wie bisher aus einer Zeichenkette (zum Beispiel "/4/1/3/1/2/"), sondern auch typsicherer auf Basis einer anderen HierarchyId und Ganzzahlen erstellen. Das folgende Beispiel zeigt den Einsatz der neuen Überladungen von HierarchyId.Parse().
// alt
var level2 = $"{startLevel}{i}/{j}/";
var hid2Alt = HierarchyId.Parse(level2);
// neu
var hid2Neu = HierarchyId.Parse(abteilungsleiter.Level, j);
Die Erstellung von Konventionen für die Modellerstellung hat Microsoft verschlankt, wie ein Beispiel in der Dokumentation zeigt
https://learn.microsoft.com/en-us/ef/core/what-is-new/ef-core-9.0/whatsnew#make-existing-model-building-conventions-more-extensible.
Verbesserungen bei den Entity Framework Core-Kommandozeilenwerkzeugen
Die Entity Framework Core-Kommandozeilenwerkzeuge sollen nun seltener eine Neukompilieren des Projekts erfordern. Ein Community-Mitglied hat dazu einen Beitrag geleistet:
https://github.com/dotnet/efcore/pull/32860.
Auch die Verbesserungen für die Sequenzen und den Füll-Faktor sowie die Erweiterung von To
Hash
SetAsync() kamen von Personen, die nicht bei Microsoft angestellt sind.
Automatisch kompilierte Modelle
Entity Framework Core erzeugt zur Laufzeit einigen Programmcode für das Mapping eines
Objekt
modells auf ein Datenbankschema. Diese Laufzeitcodegenerierung kann bei großen
Objekt
modellen zeitaufwendig sein. Zudem ist Laufzeitcodegenerierung nicht kompatibel mit dem
Ahead-of-Time-Compiler
Native AOT
, den es seit
.NET 7.0
gibt und den Microsoft in
.NET 9.0
auch mit Entity Framework Core ermöglichen will.
Seit Version 6.0 des modernen objektrelationalen Mappers gibt es bereits kompilierte Modelle, bei denen ein Teil der Laufzeitcodegenerierung zur Entwicklungszeit stattfindet. Dazu musste man zuerst einen Kommandozeilenbefehl ausführen
dotnet ef dbcontext optimize
beziehungsweise in der
PowerShell
:
Optimize-DbContext
Danach musste man im Programmcode noch einen
Methode
naufruf in OnConfiguring() ergänzen:
.UseModel(Kontextname.Instance)
Zudem mussten Entwicklerinnen und Entwickler die kompilierten Modelle an der Kommandozeile immer wieder neu erzeugen, wenn es Änderungen am
Objekt
modell oder der Kontextklasse gab.
Alle diese Schritte können nun entfallen. Das Kompilieren lässt sich mit einem neuen
MSBuild
-Task <EFOptimizeContext> automatisieren. Dazu muss man das neue
NuGet
-Paket Microsoft.EntityFrameworkCore.Tasks einbinden und dann in der Projektdatei die Einstellung <EFOptimizeContext> auf true setzen:
<
Property
Group>
<EFOptimizeContext>true</EFOptimizeContext>
</
Property
Group>
Bei jedem Übersetzungsvorgang sieht man dann:
Optimizing DbContext…
Anpassungen der Modellkompilierung sind über weitere Einstellungen wie EFStartupProject, DbContextName und EFTargetNamespace möglich.
Der Aufruf UseModel() ist seit Entity Framework Core 9.0 Preview 3 nicht mehr notwendig, sofern das kompilierte Modell in der gleichen
Assembly
liegt wie die Kontextklasse. Dies gilt unabhängig davon, ob man den
MSBuild
-Task einsetzt oder die Modellkompilierung weiterhin von Hand anstößt.
Querverweise zu anderen Begriffen im Lexikon
Datenbankmanagementsystem (DBMS)
Entity Framework Core 2.0
Entity Framework Core 8.0
Ahead-of-Time-Compiler
Microsoft SQL Server (MSSQL)
Native AOT (NAOT)
PowerShell (PS)
.NET 8.0 (.NET 8)
Property
.NET 7.0 (.NET 7)
Assembly
.NET 9.0 (.NET 9)
Methode
Caching
Objekt
await
Hash
Microsoft .NET Build Engine (MSBuild)
NuGet Library Package Manager (NuGet)
Language Integrated Query (LINQ)
JavaScript Object Notation (JSON)
Work Item Types (WIT)
Application Programming Interface (API)
Beratung & Support
Anfrage für Beratung/Consulting zu Entity Framework Core 9.0
Gesamter Beratungsthemenkatalog
Technischer Support zum Entity Framework Core 9.0
Schulungen zu diesem Thema
Entity Framework Core 9.0 - Änderungen und Neuerungen gegenüber Entity Framework Core 8.0
.NET-Entwickler-Update 2024
.NET 9.0 - Änderungen und Neuerungen gegenüber .NET 8.0
Anfrage für eine individuelle Schulung zum Thema Entity Framework Core 9.0
Gesamter Schulungsthemenkatalog
Bücher zu diesem Thema
.NET 9.0 Update: Die Neuerungen in .NET 9.0 gegenüber .NET 8.0
PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
.NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
Blazor 8.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 8.0, C# 12.0 und Visual Studio 2022
Moderne Datenzugriffslösungen mit Entity Framework Core 8.0
C# 12.0 Crashkurs
Cross-Plattform-Apps mit .NET MAUI entwickeln
Blazor 7.0: Blazor WebAssembly, Blazor Server und Blazor Hybrid
C# 11.0 Crashkurs
Moderne Datenzugriffslösungen mit Entity Framework Core 7.0
PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
App Engineering: SwiftUI, Jetpack Compose, .NET MAUI und Flutter
Vue.js 3 Crashkurs
Moderne Datenzugriffslösungen mit Entity Framework Core 6.0
Blazor 6.0: Blazor WebAssembly, Blazor Server und Blazor Desktop
C# 10.0 Crashkurs
Cross-Plattform-Apps mit Xamarin.Forms entwickeln
Developing Web Components with TypeScript: Native Web Development Using Thin Libraries
PowerShell – kurz & gut
C# 9.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET 5.0, .NET Core und Xamarin
ASP.NET Core Blazor 5.0: Blazor WebAssembly und Blazor Server - Moderne Single-Page-Web-Applications
Windows PowerShell 5 und PowerShell 7: Das Praxisbuch
Moderne Datenzugriffslösungen mit Entity Framework Core 5.0
ASP.NET Core Blazor 3.1/3.2: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
ASP.NET Core Blazor 3.0/3.1: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
Moderne Datenzugriffslösungen mit Entity Framework Core 3.1
C# 8.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
Moderne Datenzugriffslösungen mit Entity Framework Core 3.0
Windows PowerShell 5.1 und PowerShell Core 6.1 - Das Praxishandbuch
Moderne Datenzugriffslösungen mit Entity Framework Core 2.1/2.2
Moderne Webanwendungen für .NET-Entwickler: Server-Anwendungen, Web APIs, SPAs & HTML-Cross-Platform-Anwendungen mit ASP.NET, ASP.NET Core, JavaScript
C# 7.3 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
Modern Data Access with Entity Framework Core: Database Programming Using .NET, .NET Core, UWP, and Xamarin with C#
Windows PowerShell und PowerShell Core - Der schnelle Einstieg: Skriptbasierte Systemadministration für Windows, Linux und macOS
Programmierung in Python
C# 7.2 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
Moderne Datenzugriffslösungen mit Entity Framework Core 2.0/2.1
Effizienter Datenzugriff mit Entity Framework Core: Datenbankprogrammierung mit C# für .NET Framework, .NET Core und Xamarin
Moderne Datenzugriffslösungen mit Entity Framework Core 2.0
Windows PowerShell 5 und PowerShell Core 6 - Das Praxishandbuch
Angular - Das Praxisbuch zu Grundlagen und Best Practices
Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
Moderne Datenzugriffslösungen mit Entity Framework Core 1.1 und 2.0-Preview2
Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
Introducing Regular Expressions: JavaScript and TypeScript
Introducing Web Development
Introducing Bootstrap 4
Programming Web Applications with Node, Express and Pug
Einführung in TypeScript: Grundlagen der Sprache TypeScript 2
Pug – Die Template-Engine für node.js
Web-Programmierung mit Node, Express und Pug
Windows PowerShell 5 – kurz & gut
Moderne Datenzugriffslösungen mit Entity Framework Core 1.1
Windows PowerShell 5.0 - Das Praxishandbuch
PHP 7 und MySQL: Von den Grundlagen bis zur professionellen Programmierung
Windows Scripting Lernen
.NET Praxis - Tipps und Tricks für .NET und Visual Studio
Grundlagen für Web-Entwickler: Protokolle, HTML und CSS
Bootstrap 3 - Stile und Komponenten
Bootstrap 4 - Stile und Komponenten
Einführung in JavaScript: ECMAScript 5
Einführung in node.js
express – Middleware für node.js
JADE – Die Template Engine für node.js
Reguläre Ausdrücke in JavaScript
Moderne Datenzugriffslösungen mit Entity Framework 6
C++ Standardbibliothek
AngularJS: Moderne Webanwendungen und Single Page Applications mit JavaScript
Microsoft SharePoint Server 2013 und SharePoint Foundation: Das umfassende Handbuch
SQL Server 2014 für Professionals: Hochverfügbarkeit, Cloud-Szenarien, Backup/Restore, Monitoring & Performance
Moderne Webanwendungen mit ASP.NET MVC und JavaScript
Windows PowerShell 4.0 - Das Praxishandbuch
JavaScript: Das umfassende Handbuch, inkl. HTML5, JavaScript-Frameworks, jQuery, OOP
C++11 für Programmierer
C++ kurz und gut
Microsoft ASP.NET 4.5 - Entwicklerbuch
Moderne Webanwendungen mit ASP.NET MVC
Verteilte Systeme und Services mit .NET 4.5
Scripting mit Windows PowerShell 3.0 - Der Workshop: Skript-Programmierung mit Windows PowerShell 3.0 vom Einsteiger bis zum Profi
Windows 8 für Administratoren
Windows 8.1 - Das Handbuch (27. November 2013)
Windows Store Apps entwickeln mit C# und XAML - Crashkurs
.NET 4.5 Update
Windows Scripting Lernen
WPF 4.5 und XAML
Datenbankprogrammierung mit .NET 4.5
C++11: Der Leitfaden für Programmierer zum neuen Standard
Verteilte Systeme und Services mit .NET 4.0
Microsoft ASP.NET 4.0 mit C# 2010 - Entwicklerbuch
Agile Software Engineering with Visual Studio
Datenbankprogrammierung mit .NET 4.0. Mit Visual Studio 2010 und SQL Server 2008 R2
Microsoft SharePoint Server 2010 und SharePoint Foundation 2010
Microsoft SQL Server 2008 R2 - Das Entwicklerbuch
Microsoft Viusal C# 2010
Office 2010 Programmierung mit VSTO und .NET 4.0: Word, Excel und Outlook erweitern und anpassen
Programmieren mit dem ADO.NET Entity Framework
.NET 4.0 Crashkurs
Visual Basic 2010: Grundlagen, ADO.NET, Windows Presentation Foundation
.NET 4.0 Update
Windows PowerShell 2.0 - Das Praxishandbuch
Windows 7 im Unternehmen
Agile Muster und Methoden
Ajax
ASP.NET 4.0
ASP.NET 4.0 mit Visual C# 2010
JavaScript
PHP 5-Migration
Scripting mit Windows PowerShell 2.0 - Der Einsteiger-Workshop
SQL Server 2008 R2: Das Programmierhandbuch. Inkl. ADO.NET 3.5, LINQ to Entities und LINQ to SQL
Visual Basic 2010
Windows PowerShell 2.0 - Crashkurs
Windows Server 2008 R2
Windows Scripting
Windows Scripting Lernen
Data Mining mit Microsoft SQL Server
Windows 7 für Administratoren
Microsoft ASP.NET 3.5 mit Visual Basic 2008 - Entwicklerbuch
.NET 3.5
Essential PowerShell
.NET 3.5 Crashkurs
Webanwendungen mit ASP.NET 3.5 und AJAX Crashkurs
Alle unsere aktuellen Fachbücher
E-Book-Abo für ab 99 Euro im Jahr