Sie sind hier: Wissen

Was ist LINQ-to-Dataset ?

LINQ to DataSet ermöglicht es, die in einem ADO.NET-DataSet enthaltenen Daten per LINQ auszuwerten. Optional können Sie die Ergebnisse anschließend in DataTable- oder DataView-Objekte umwandeln.

WICHTIGER HINWEIS

LINQ-to-Dataset wird immer im RAM ausgeführt auf bereits geladenen Datasets. Es ist nicht möglich, mit LINQ-to-Dataset Abfragen zu definieren, um Datasets zu befüllen. Wenn Sie von LINQ als Ersatz für SQL träumen, sollten Sie sich das ADO.NET Entity Framework ansehen.

Details

LINQ-to-DataSet ermöglicht die Abfrage von Daten in einem Dataset. Die vor .NET 3.5 in einem Dataset vorhandenen Möglichkeiten zum Filtern mit der Methode Select() und der Klasse DataView sowie dem Verknüpfen mit der DataRelation-Klasse waren sehr bescheiden. Mit LINQ-to-DataSet sind nun vielfäl-tige Suchabfragen und Verknüpfungen über beliebige Spalten (Joins) möglich. Außerdem liefert LINQ-to-DataSet Verbesserungen hinsichtlich der Typisierung bei untypisierten DataSets.

Es können sowohl typisierte als auch untypisierte Datasets verwendet werden. LINQ-to-DataSet ist eine Schicht oberhalb des Datasets. Unterhalb (Datenprovider, Datenverbindungen, Befehlsobjekt) ändert sich durch den Einsatz von LINQ-to-DataSet nichts.

Voraussetzung für die Nutzung von LINQ-to-DataSet ist die Referenzierung der Assembly Sys-tem.Data.DataSetExtensions.dll, die Erweiterungen für die Klasse DataTable (DataTableExtensions) und DataRow (DataRowExtensions) bereitstellt.

Abfragen über eine Tabelle

Um eine LINQ-Abfrage über eine Tabelle in Form eines DataTable-Objekts ausführen zu können, muss das DataTable-Objekt in ein Objekt des Typs System.Data.EnumerableRowCollection<System.Data.DataRow> umgewandelt werden. Dies geschieht mithilfe der Erweiterungsmethode AsEnumerable().
// --- Tabelle aus einem vorher befüllten DataSet
DataTable AlleFluege = ds.Tables["Fluege"];

// --- LINQ Abfrage
Ienumerable<DataRow> FluegeVonRom =
from Flug in AlleFluege.AsEnumerable()
where Convert.ToDateTime(Flug["FL_Datum"]) >
new DateTime(2008, 1, 1) &&
Flug["FL_AbflugOrt"].ToString() == "Rom"
select Flug;
Listing: Eine LINQ-Abfrage über ein zuvor befülltes DataTable-Objekt


Zur Formulierung der Abfrage kann man alternativ auch die durch die Klasse DataRowExtensions bereit-gestellte generische Erweiterungmethode Field<Typ>() verwendet werden, um die Spalten anzusprechen. In typisierten DataSets können die Spalten direkt über die Punktnotation angesprochen werden.
// --- Tabelle aus einem vorher befüllten DataSet
DataTable AlleFluege = ds.Tables["Fluege"];

// --- LINQ Abfrage
Ienumerable<DataRow> FluegeVonRom =
from Flug in AlleFluege.AsEnumerable()
where Flug.Field<DateTime>("FL_Datum") >
new DateTime(2008, 1, 1) &&
Flug.Field<string>("FL_AbflugOrt") == "Rom"
select Flug;
Listing: Eine LINQ-Abfrage über ein zuvor befülltes DataTable-Objekt (Alternative)

Das Ergebnis der Abfrage ist – sofern keine Projektion festgelegt wird, wieder eine Menge des Typs System.Data.EnumerableRowCollection<System.Data.DataRow>. Meist verwendet man als Typ aber allgemein die Schnittstelle Ienumerable<DataRow>.
Ein DataTable-Objekt kann man durch Aufruf der Methode CopyToDataTable() erhalten. Die Methode AsDataView() liefert ein DataView-Objekt.

Das folgende Beispiel zeigt die Abfrage eines typisierten Datasets mit LINQ-to-DataSet.

Public void DatasetTDSLINQ()
{
Console.WriteLine("Flüge von ROM (TDS mit lokalem Filter über LINQ-to-DataSet )");

// Tabellenadapter instanziieren
TDS.WWWingsTDSTableAdapters.FLFluegeTableAdapter ta = new de.WWWings.Test.TDS.WWWingsTDSTableAdapters.FLFluegeTableAdapter();
// Typisiertes DataSet instanziieren
TDS.WWWingsTDS.FLFluegeDataTable AlleFluege = new de.WWWings.Test.TDS.WWWingsTDS.FLFluegeDataTable();
// Tabelle laden
ta.Fill(AlleFluege);

var FluegeVonRom =
from Flug in AlleFluege
where Flug.FL_Datum > new DateTime(2008, 1, 1)
&& Flug.FL_Abflugort == "Rom"
select Flug;

// --- Iteration über Daten
foreach (TDS.WWWingsTDS.FL_FluegeRow dr in FluegeVonRom)
{
Console.WriteLine("Flugnummer: " + dr.FLFlugNr + ": " + dr.FL_Abflugort + "->" + dr.FL_Zielort + ". Freie Plätze: " + dr.FLFreiePlaetze);

if (!dr.IsFl_StartZeitNull()) Console.WriteLine("Kein StartDatum gesetzt!");
}
}
Listing:LINQ-to-DataSet mit typisiertem Dataset

Abfragen über mehrere Tabellen (Joins)

Mit der Klasse DataRelation (seit .NET 1.0 vorhanden) kann man nur hierarchische Eltern-Kind-Beziehungen erzeugen. Echte relationale Beziehungen (Joins) kann man mit dem join-Operator in LINQ-to-DataSet erzeugen, siehe nachfolgendes Beispiel.

Public void Dataset_Beziehungen()
{
Console.WriteLine("Passagiere mit ihren Flügen");

// --- Parameter
string CONNSTRING = @"Data Source=.\SQLEXPRESS;AttachDbFilename=H:\WWW\Datenbanken\WorldWideWings1.mdf;Integrated Security=True;Connect Timeout=30;User Instance=True";
const string SQL1 = "Select * from AllePassagiere";
const string SQL2 = "Select * from GF_GebuchteFluege";

// --- Verbindung aufbauen
SqlConnection conn = new SqlConnection(CONNSTRING);
conn.Open();
// --- Leeres DataSet erzeugen
DataSet ds = new DataSet();
// --- Datenadapter erzeugen
SqlDataAdapter da1 = new SqlDataAdapter(SQL1, CONNSTRING);
SqlDataAdapter da2 = new SqlDataAdapter(SQL2, CONNSTRING);
// --- Daten abholen
da1.Fill(ds, "AllePassagiere");
da2.Fill(ds, "GebuchteFluege");
// --- Verbindung jetzt schon schließen!
Conn.Close();

// --- Zeiger auf Tabellen
DataTable AllePassagiere = ds.Tables["AllePassagiere"];
DataTable GebuchteFluege = ds.Tables["GebuchteFluege"];

// --- Join definieren
var Abfrage =
from p in AllePassagiere.AsEnumerable()
join b in GebuchteFluege.AsEnumerable()
on p.Field<int>("PS_ID") equals
b.Field<int>("GFPSID")
where p.Field<int>("AnzahlFluege") > 0
select new
{
FlugNr =
b.Field<int>("GFFLFlugNr"),
Vorname =
p.Field<string>("PE_Vorname"),
Name =
p.Field<string>("PE_Name"),
PassagierID =
p.Field<int>("PS_ID")
};

// --- Ergebnis anzeigen
foreach (var Ergebnis in Abfrage)
{
Console.WriteLine("Pasagier: " + Ergebnis.PassagierID + " Name: " + Ergebnis.Name + " Vorname: " + Ergebnis.Vorname + " gebucht auf Flug " + Ergebnis.FlugNr);
}
}
}
Listing: Join zwischen zwei Tabellen in einem DataSet

Beratung & Support

Schulungen zu diesem Thema

 Anfrage für eine individuelle Schulung zum Thema LINQ-to-Dataset  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