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: LINQ-to-Dataset
Zur Stichwortliste unseres Lexikons
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-
Objekt
e 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
DataSet
s.
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.
DataSet
Extensions.dll, die Erweiterungen für die Klasse
DataTable
(
DataTable
Extensions) und DataRow (DataRowExtensions) bereitstellt.
Abfragen über eine Tabelle
Um eine
LINQ
-Abfrage über eine Tabelle in Form eines
DataTable
-
Objekt
s 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
DataSet
s 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 CopyTo
DataTable
() erhalten. Die Methode AsDataView() liefert ein DataView-
Objekt
.
Das folgende Beispiel zeigt die Abfrage eines typisierten Datasets mit
LINQ
-to-
DataSet
.
Public void Dataset
TDS
LINQ
()
{
Console.WriteLine("Flüge von ROM (
TDS
mit lokalem Filter über
LINQ
-to-
DataSet
)");
// Tabellenadapter instanziieren
TDS
.
WWW
ings
TDS
TableAdapters.FL
FluegeTableAdapter ta = new de.
WWW
ings.Test.
TDS
.
WWW
ings
TDS
TableAdapters.FL
FluegeTableAdapter();
// Typisiertes
DataSet
instanziieren
TDS
.
WWW
ings
TDS
.FL
Fluege
DataTable
AlleFluege = new de.
WWW
ings.Test.
TDS
.
WWW
ings
TDS
.FL
Fluege
DataTable
();
// 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
.
WWW
ings
TDS
.FL_FluegeRow dr in FluegeVonRom)
{
Console.WriteLine("Flugnummer: " + dr.FL
FlugNr + ": " + dr.FL_Abflugort + "->" + dr.FL_Zielort + ". Freie Plätze: " + dr.FL
FreiePlaetze);
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=.\
SQL
EXPRESS;AttachDbFilename=H:\
WWW
\
Datenbank
en\WorldWideWings1.mdf;Integrated Security=True;Connect Timeout=30;User Instance=True";
const string
SQL
1 = "Select * from AllePassagiere";
const string
SQL
2 = "Select * from GF_GebuchteFluege";
// --- Verbindung aufbauen
SqlConnection conn = new SqlConnection(CONNSTRING);
conn.Open();
// --- Leeres
DataSet
erzeugen
DataSet
ds = new
DataSet
();
// --- Datenadapter erzeugen
Sql
DataAdapter
da1 = new Sql
DataAdapter
(
SQL
1, CONNSTRING);
Sql
DataAdapter
da2 = new Sql
DataAdapter
(
SQL
2, 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>("GF
PS
ID")
where p.
Field
<int>("AnzahlFluege") > 0
select new
{
FlugNr =
b.
Field
<int>("GF
FL
FlugNr"),
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
Querverweise zu anderen Begriffen im Lexikon
ADO.NET Entity Framework (EF)
Erweiterungsmethode
DataAdapter
System.Data
DataTable
Datenbank (DB)
Assembly
.NET 3.5
DataSet
Objekt
Field
.NET Framework 1.0 (.NET 1.0)
Language Integrated Query (LINQ)
Structured Query Language (SQL)
Tabular Data Stream (TDS)
World Wide Web (WWW)
Beratung & Support
Anfrage für Beratung/Consulting zu LINQ-to-Dataset
Gesamter Beratungsthemenkatalog
Technischer Support zum LINQ-to-Dataset
Schulungen zu diesem Thema
Language Integrated Query (LINQ)
.NET 3.5-Crashkurs - Überblick über das .NET Framework 3.5 und Visual Studio 2008 für Umsteiger von .NET 2.0/3.0
.NET 3.5-Update - Die Neuerungen in .NET Framework 3.5 und Visual Studio 2008 im Überblick
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