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 8.0
Zur Stichwortliste unseres Lexikons
Was ist
Entity Framework Core 8.0
?
Entity Framework Core 8.0 ist als Nachfolger von
Entity Framework Core 7.0
zusammen mit
.NET 8.0
erschienen.
Termine
Erscheinungstermin: 14. November 2023
Support: 3 Jahre, also bis November 2026
Hinweise
Entity Framework Core 8.0 läuft nur auf
.NET 8.0
! (bis Preview 6 lief es noch auf
.NET 6.0
,
.NET 7.0
und
.NET 8.0
)
Microsoft kürzt Entity Framework Core 8.0 mit "EF8" ab.
Liste
der wesentlichen Neuerungen in Entity Framework Core 8.0
Mapping für die in
.NET 6.0
eingeführten elementaren Typen System.DateOnly und System.TimeOnly auch im
Microsoft SQL Server
Datentypen long und ulong für Timestamp-Spalten als Alternative zu Byte-Arrays (nur im
Microsoft SQL Server
)
Mapping von Arrays und
Liste
n elementarer Typen auf nvarchar-Spalten mit
JSON
-Zeichenketten
JSON
-Mapping von Klassen mit ToJson() auch für
SQLite
-Datenbanken (das war seit
Entity Framework Core 7.0
nur im SQL Server möglich)
Table Splitting mit Complex Types als Alternative zu den bisher verfügbaren Owned Types via
Annotation
[ComplexType] oder Fluent-
API
per Methodenaufruf Complex
Property
()
Hierarchische Daten im SQL Server mit dem SQL Server-Spaltentyp "hierarchyid" via NuGet-Paket Microsoft.EntityFrameworkCore.SqlServer.HierarchyId
Mapping von SQL-Abfragen auf beliebige, nicht in der Kontextklasse registrierte Typen mit ctx.Database.SqlQuery() und ctx.Database.SqlQueryRaw()
Das
Lazy Loading
funktioniert auch bei No-Tracking-Abfragen
Abschalten des
Lazy Loading
für einzelne Beziehungen mit EnableLazyLoading(false)
Asynchrones explizites Nachladen mit Reference().LoadAsync() bzw. Collection().LoadAsync() zusätzlich zum synchronen Load()
Automatisch begrenzte Länge der Diskriminatorspalten bei Table-per-Hierarchy-
Vererbung
Bessere SQL-Übersetzung des
LINQ
-Operators Contains(): es entstehen parametrisierte Abfragen statt Ad-hoc-Abfragen und bei Unterabfragen kommt WHERE…IN zum Einsatz.
Übersichtlichere SQL-Generierung aus
LINQ
-Abfragen ohne überflüssige Klammern
Abfrage der
Objekt
e im lokalen Zwischenspeicher mit Local.FindEntry() und Local.GetEntries()
Statusabfrage, ob es Änderungen im
Objekt
modell gibt, für die es noch keine Datenbankschemamigration gibt: Via Kommandozeile dotnet ef migrations has-pending-model-changes
Festlegung des von Entity Framework Core intern verwendeten Wächterwertes, um festzustellen, dass ein Wert nicht der im
Datenbankmanagementsystem
hinterlegte Standardwert ist: HasSentinel()
Die in
Entity Framework Core 7.0
eingeführten Methoden ExecuteUpdate() and ExecuteDelete() funktionieren in Version 8.0 auch in Fällen, bei denen mehrere Entitätsklassen auf eine einzige Tabelle (z.B. bei der TPH-
Vererbung
) abgebildet sind
Verbessertes Datentypmapping in Entity Framework Core 8.0
Der
Objekt
-Relationale Mapper Entity Framework Core in Version 8.0 erlaubt nun die Abbildung der bereits in
.NET 6.0
eingeführten Klassen DateOnly und TimeOnly auf die SQL-Server-Datentypen date und time. Das ging bisher (schon seit
.NET 6.0
) nur bei
SQLite
-Datenbanken.
Umgekehrt konnte zuvor nur der
Microsoft SQL Server
-Treiber für Entity Framework Core mit einem
JSON
-Mapping umgehen (seit
Entity Framework Core 7.0
). Seit Preview 2 von Entity Framework Core 8.0 können Entwickler nun die in eingeführten
JSON
-Spalten auch in Verbindung mit
SQLite
-Datenbanken nutzen, indem man im Fluent-
API
der Kontextklasse bei einem Owned Type ToJson() aufruft. Dadurch werden verbundene
Objekt
e auf einzelne Datenbankspalten mit
JSON
-Inhalt abgebildet. Abfragen mit Filtern und Sortieren sind dennoch möglich.
Mapping von Arrays und einfachen
Liste
n
Der OR-Mapper konnte bisher (außer bei
PostgreSQL
) keine Mengen elementarer Datentypen auf die Datenbank abbilden. Bei der Verwendung von Mengen-Typen wie Arrays, List, Queue, Stack und
Hash
Set (z.B. int[], List<DateTime> und
Hash
Set<Guid>) verweigerte Entity Framework Core das Mapping mit der Fehlermeldung "The property 'DataTypeTest.xy' could not be mapped because it is of type 'xy[]', which is not a supported primitive type or a valid entity type. Either explicitly map this property, or ignore it using the '[NotMapped]' attribute or by using 'EntityTypeBuilder.Ignore' in 'OnModelCreating'." Nur im
PostgreSQL
-Treiber für Entity Framework Core [
https://www.npgsql.org/efcore
] war dies möglich, denn dieses
Datenbankmanagementsystem
unterstützt von Hause aus Arrays als Spaltentypen.
In Entity Framework Core 8.0 hat Microsoft nun für
Microsoft SQL Server
und
SQLite
eine andere Lösung implementiert: Dort werden alle im Listing gezeigten Mengentypen auf eine
JSON
-Spalte abgebildet. Für alle Mengentypen im nächsten Listing entsteht jeweils eine Spalte vom Typ nvarchar(max) in SQL Server bzw. TEXT in
SQLite
, welche dann die Elemente der String-Menge als
JSON
-Array abspeichert.
Listing: Entitätsklasse mit Array-Typen
public class DataTypeTest
{
public Int32 ID { get; set; }
public byte[] ByteArray { get; set; }
[Timestamp]
public byte[] Timestamp { get; set; }
public short[] ShortArray { get; set; }
public int[] IntArray { get; set; }
public long[] LongArray { get; set; }
public string[] StringArray { get; set; }
public DateTime[] DateTimeArray { get; set; }
public bool[] BoolArray { get; set; }
public Guid[] GuidArray { get; set; }
public ABC[] EnumArray { get; set; }
public List<int> IntList { get; set; }
// analog auch alle o.g. Array-Typen als List<T>
}
Hierarchische Daten im SQL Server mit Entity Framework Core 8.0
Beim
Microsoft SQL Server
werden seit Entity Framework Core 8.0 Preview 2 auch Tabellen mit hierarchischen Daten mit dem SQL Server-Spaltentyp Hierarchy-ID unterstützt. Dazu gab es bisher ein NuGet-Paket aus der Community "EntityFrameworkCore.SqlServer.HierarchyId" [
https://www.nuget.org/packages/EntityFrameworkCore.SqlServer.HierarchyId
]. Nun hat Microsoft diese Funktionen in den Kern von Entity Framework Core aufgenommen. Man benötigt dafür zwei Pakete:
Das Paket Microsoft.EntityFrameworkCore.SqlServer.Abstractions stellt die Klasse Microsoft.EntityFrameworkCore.HierarchyId bereit, die man auf der Ebene der Geschäftsobjekte braucht, um eine Hierarchie zu definieren (siehe Klasse "Mitarbeiter" in Listing 1). Ebenso braucht man das Paket dort, wo man
LINQ
-Befehle auf der HierarchyId absetzen will, z.B. mit den Operationen GetAncestor(), GetDescendant(), IsDescendantOf() und GetLevel(), siehe Listing 3.
Das Paket Microsoft.EntityFrameworkCore.SqlServer.HierarchyId benötigt man in der Kontextklasse für die
Erweiterungsmethode
UseHierarchyId(), siehe Listing 2.
Listing 1 bis 3 zeigen ein zusammenhängendes, aussagekräftiges Beispiel für hierarchische Daten mit Entity Framework Core 8.0. Die Geschäftsobjektklasse Mitarbeiter in Listing 7 besitzt eine Eigenschaft Ebene vom Typ HierarchyId. Listing 2 realisiert eine Entity Framework Core-Kontextklasse für diese Geschäftsobjektklasse.
In Listing 3 findet man einen Client, der zunächst eine Mitarbeiterhierarchie und dann verschiedene Abfragen ausführt. Am Ende wird auch noch ein Mitarbeiter befördert, d.h. seine Ebene wird geändert.
Listing 1: Klasse Mitarbeiter mit HierarchyId
public class Mitarbeiter
{
public Mitarbeiter(HierarchyId ebene, string name, int? eintrittsjahr = null)
{
Ebene = ebene;
Name = name;
Eintrittsjahr = eintrittsjahr;
}
public int ID { get; private set; }
public HierarchyId Ebene { get; set; }
public string Name { get; set; }
public int? Eintrittsjahr { get; set; }
public override string ToString()
{
return $"Mitarbeiter {ID} Ebene {Ebene}: {Name}";
}
}
Listing 2: Entity Framework Core-Kontextklasse für die Geschäftsobjektklasse Mitarbeiter
class Context : DbContext
{
public DbSet<Mitarbeiter> MitarbeiterSet { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder builder)
{
builder.EnableSensitiveDataLogging(true);
builder.UseSqlServer(@$"Server=D120;Database=Entity Framework Core
MappingScenarios_" + nameof(EFC80_HierarchicalData) + ";Trusted
Connection=True;MultipleActiveResultSets=True;encrypt=false", x => x.UseHierarchyId());
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
}
}
Listing 3: Aufbau und Auslesen einer Mitarbeiterhierarchie
class Client
{
public void Run()
{
using (var ctx = new Context())
{
CUI
.H2("Mitarbeiterhierarchie erzeugen");
Randomizer.Seed = new Random(42);
var f = new Faker();
var startEbene = "/";
var bosmang = new Mitarbeiter(HierarchyId.Parse(startEbene), f.Name.FullName(), f.Random.Number(1970, 2023));
Console.WriteLine(bosmang);
ctx.Add(bosmang);
for (int I = 1; I < 5; i++)
{
var ebene1 = startEbene + I + "/";
var m = new Mitarbeiter(HierarchyId.Parse(ebene1), f.Name.FullName(), f.Random.Number(1970, 2023));
Console.WriteLine(" " + m);
ctx.Add(m);
for (int j = 1; j < 5; j++)
{
var ebene2 = startEbene + I + "/" + j + "/"; ;
var n = new Mitarbeiter(HierarchyId.Parse(ebene2), f.Name.FullName(), f.Random.Number(1970, 2023));
Console.WriteLine(" " + n);
ctx.Add(n);
}
}
var c = ctx.SaveChanges();
Console.WriteLine©;
CUI
.H2("Daten auslesen mit GetLevel()");
for (int ebene = 0; ebene <= 3; ebene++)
{
var mitarbeiterAufEinerEbene = ctx.MitarbeiterSet.Where(x => x.Ebene.GetLevel() == ebene).ToList();
CUI
.H3($"Mitarbeiter auf Ebene {ebene}:");
foreach (var m in mitarbeiterAufEinerEbene)
{
Console.WriteLine(m);
}
}
CUI
.H2("Daten auslesen mit GetAncestor ()");
var irgendEinMitarbeiter = ctx.MitarbeiterSet.ToList().ElementAt(15);
var vorgesetzter = ctx.MitarbeiterSet.SingleOrDefault(
ancestor => ancestor.Ebene == irgendEinMitarbeiter.Ebene.GetAncestor(1));
Console.WriteLine($"Der Vorgesetzte von {irgendEinMitarbeiter.Name} ist: {vorgesetzter.Name}");
CUI
.H2("Daten auslesen mit IsDescendantOf()");
var mitarbeiterEinerFuehrungskraft = ctx.MitarbeiterSet.Where(x => x.Ebene.IsDescendantOf(vorgesetzter.Ebene) && x.ID != vorgesetzter.ID).ToList();
Console.WriteLine($"Alle Mitarbeiter von {vorgesetzter.Name}:");
foreach (var m in mitarbeiterEinerFuehrungskraft)
{
Console.WriteLine(m);
}
CUI
.H2("Daten ändern: Ein Mitarbeiter wird befördert und steigt auf die Ebene direkt unter dem Bosmang auf");
Console.WriteLine($"{irgendEinMitarbeiter.Name} Alte Ebene: {irgendEinMitarbeiter.Ebene}");
irgendEinMitarbeiter.Ebene = irgendEinMitarbeiter.Ebene.GetReparentedValue(vorgesetzter.Ebene, bosmang.Ebene);
Console.WriteLine($"{irgendEinMitarbeiter.Name} Neue Ebene: {irgendEinMitarbeiter.Ebene}");
ctx.SaveChanges();
CUI
.H2("Daten auslesen mit IsDescendantOf()");
var alleUnterDemBosmang = ctx.MitarbeiterSet.Where(x => x.Ebene.IsDescendantOf(bosmang.Ebene) && x.Ebene.GetLevel() == 1).ToList();
Console.WriteLine($"Alle Mitarbeiter unter dem Bosmang:");
foreach (var m in alleUnterDemBosmang)
{
Console.WriteLine(m);
}
}
}
}
Querverweise zu anderen Begriffen im Lexikon
Datenbankmanagementsystem (DBMS)
Entity Framework Core 7.0
Microsoft SQL Server (MSSQL)
Erweiterungsmethode
Lazy Loading
Annotation
PostgreSQL
Vererbung
.NET 8.0 (.NET 8)
Property
.NET 7.0 (.NET 7)
.NET 6.0 (.NET 6)
Objekt
SQLite
Liste
Hash
Language Integrated Query (LINQ)
JavaScript Object Notation (JSON)
Application Programming Interface (API)
Console User Interface (CUI)
Beratung & Support
Anfrage für Beratung/Consulting zu Entity Framework Core 8.0
Gesamter Beratungsthemenkatalog
Technischer Support zum Entity Framework Core 8.0
Schulungen zu diesem Thema
Entity Framework Core 8.0 - Änderungen und Neuerungen gegenüber Entity Framework Core 7.0
Umstieg auf Entity Framework Core 8.0/9.0 (Umstellung/Migration von Entity Framework 6.0/7.0/8.0)
Entity Framework Core 8.0/9.0 (EF Core 8.0/9.0): Objekt-Relationales Mapping (ORM) für .NET 8.0/9.0 (komplettes Wissen)
Entity Framework Core 9.0 - Änderungen und Neuerungen gegenüber Entity Framework Core 8.0
.NET 8.0 - Änderungen und Neuerungen gegenüber .NET 7.0
.NET-Entwickler-Update 2023
Anfrage für eine individuelle Schulung zum Thema Entity Framework Core 8.0
Gesamter Schulungsthemenkatalog
Bücher zu diesem Thema
Blazor 9.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 9.0, C# 13.0 und Visual Studio 2022
C# 13.0 Crashkurs
Moderne Datenzugriffslösungen mit Entity Framework Core 9.0
.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