Gewusst wie: Zurückgeben eines LINQ-Abfrageergebnisses als ein bestimmter Typ (Visual Basic)
Language-Integrated Query (LINQ) vereinfacht den Zugriff auf Datenbankinformationen und das Ausführen von Abfragen.Standardmäßig geben LINQ-Abfragen eine Liste von Objekten als anonyme Typen zurück.Mithilfe der Select-Klausel können Sie auch angeben, dass eine Abfrage eine Liste eines bestimmten Typs zurückgibt.
Im folgenden Beispiel wird gezeigt, wie eine neue Anwendung erstellt wird, die eine SQL Server-Datenbank abfragt und die Ergebnisse als einen bestimmten benannten Typ darstellt.Weitere Informationen finden Sie unter Anonyme Typen (Visual Basic) und unter Select-Klausel (Visual Basic).
In den Beispielen dieses Themas wird die Beispieldatenbank Northwind verwendet.Wenn die Beispieldatenbank Northwind auf dem Entwicklungscomputer nicht installiert ist, können Sie sie von der Website Microsoft Download Center herunterladen.Anweisungen dazu finden Sie unter Downloading Sample Databases (LINQ to SQL).
Hinweis |
---|
Ihr Computer zeigt möglicherweise für einige der Elemente der Visual Studio-Benutzeroberfläche in der folgenden Anleitung andere Namen oder Standorte an. Diese Elemente sind von der jeweiligen Visual Studio-Version und den verwendeten Einstellungen abhängig. Weitere Informationen finden Sie unter Visual Studio-Einstellungen. |
So erstellen Sie eine Verbindung zu einer Datenbank
Öffnen Sie in Visual Studio den Server-Explorer/Datenbank-Explorer, indem Sie im Menü Ansicht auf Server-Explorer/Datenbank-Explorer klicken.
Klicken Sie im Server-Explorer/Datenbank-Explorer mit der rechten Maustaste auf Datenverbindungen und anschließend auf Verbindung hinzufügen.
Geben Sie eine gültige Verbindung zur Beispieldatenbank Northwind an.
So fügen Sie ein Projekt hinzu, das eine LINQ to SQL-Datei enthält
Zeigen Sie in Visual Studio im Menü Datei auf Neu, und klicken Sie auf Projekt.Wählen Sie Visual Basic-Windows Forms-Anwendung als Projekttyp aus.
Klicken Sie im Menü Projekt auf Neues Element hinzufügen.Wählen Sie die Elementvorlage LINQ to SQL-Klassen aus.
Nennen Sie die Datei northwind.dbml.Klicken Sie auf Hinzufügen.Der Object Relational Designer (O/R-Designer) wird für die Datei northwind.dbml geöffnet.
So fügen Sie abzufragende Tabellen zum O/R-Designer hinzu
Erweitern Sie im Server-Explorer/Datenbank-Explorer die Verbindung zur Datenbank Northwind.Erweitern Sie den Ordner Tabellen.
Wenn Sie den O/R-Designer geschlossen haben, können Sie ihn durch Doppelklicken auf die zuvor hinzugefügte Datei northwind.dbml erneut öffnen.
Klicken Sie auf die Tabelle Customers, und ziehen Sie sie in den linken Bereich des Designers.
Der Designer erstellt ein neues Customer-Objekt für das Projekt.Sie können ein Abfrageergebnis als Customer-Typ oder als einen selbst erstellten Typ projizieren.In diesem Beispiel wird ein neuer Typ in einer späteren Prozedur erstellt, und ein Abfrageergebnis wird als dieser Typ projiziert.
Speichern Sie die Änderungen, und schließen Sie den Designer.
Speichern Sie das Projekt.
So fügen Sie Code für Datenbankabfragen und zum Anzeigen der Ergebnisse hinzu
Ziehen Sie aus der Toolbox ein DataGridView-Steuerelement auf das Standard-Windows Form (Form1) des Projekts.
Doppelklicken Sie auf Form1, um die Form1-Klasse zu ändern.
Fügen Sie nach der End Class-Anweisung der Form1-Klasse den folgenden Code hinzu, um einen CustomerInfo-Typ zu erstellen, der die Abfrageergebnisse für dieses Beispiel enthält.
Public Class CustomerInfo Public Property CompanyName As String Public Property ContactName As String End Class
Wenn Sie dem O/R-Designer Tabellen hinzugefügt haben, wurde dem Projekt ein DataContext-Objekt vom Designer hinzugefügt.Dieses Objekt enthält den Code, der für den Zugriff auf diese Tabellen sowie auf einzelne Objekte und Aufzählungen jeder Tabelle benötigt wird.Das DataContext-Objekt des Projekts wird auf Grundlage des Namens der DBML-Datei benannt.Für dieses Projekt lautet der Name des DataContext-Objekts northwindDataContext.
Sie können im Code eine Instanz von DataContext erstellen und die vom O/R-Designer angegebenen Tabellen abfragen.
Fügen Sie folgenden Code im Load-Ereignis der Form1-Klasse hinzu, um die als Eigenschaften des Datenkontexts verfügbar gemachten Tabellen abzufragen.Die Select-Klausel der Abfrage erstellt für jedes Element des Abfrageergebnisses einen neuen CustomerInfo-Typ anstelle eines anonymen Typs.
Dim db As New northwindDataContext Dim customerList = From cust In db.Customers Where cust.CompanyName.StartsWith("L") Select New CustomerInfo With {.CompanyName = cust.CompanyName, .ContactName = cust.ContactName} DataGridView1.DataSource = customerList
Drücken Sie F5, um das Projekt auszuführen und die Ergebnisse anzuzeigen.
Siehe auch
Aufgaben
Walkthrough: Creating LINQ to SQL Classes (O/R Designer)
Konzepte
DataContext Methods (O/R Designer)