Exemplarische Vorgehensweise: Erstellen des Adventure Works Sales-Modells und einer Abfrage (Visual Basic)
Diese exemplarische Vorgehensweise stellt ein grundlegendes End-to-End-Szenario für LINQ-to-Entities mit minimaler Komplexität bereit. Sie erstellen das AdventureWorks Sales-Modell, das Entitäten und Zuordnungen enthält, die auf den Tabellen Contact, Address, Product, SalesOrderHeader und SalesOrderDetail der AdventureWorks-Beispieldatenbank beruhen. Sie erstellen dann eine einfache Abfrage, die alle roten Produkte im AdventureWorks-Inventar zurückgibt.
Erforderliche Komponenten
Für dieses Beispiel wird die AdventureWorks-Beispieldatenbank benötigt. Wenn Sie diese Datenbank nicht auf dem Entwicklungscomputer gespeichert haben, können Sie sie von der Microsoft SQL Server Community & Samples-Seite auf der CodePlex-Site herunterladen.
Übersicht
Diese exemplarische Vorgehensweise besteht aus vier Hauptaufgaben:
Erstellen einer LINQ-to-Entities-Projektmappe in Visual Studio 2008
Erstellen des AdventureWorks Sales-Modells
Erstellen einer einfachen Abfrage des Sales-Modells
Ausführen der Abfrage und Prüfen der Ergebnisse
Erstellen einer LINQ to Entities-Projektmappe
In dieser ersten Aufgabe erstellen Sie eine Visual Studio-Projektmappe, die die erforderlichen Verweise zur Erstellung und Ausführung eines LINQ to Entities-Projekts enthält.
So erstellen Sie eine LINQ to Entities-Projektmappe in Visual Basic
Zeigen Sie in Visual Studio im Menü Datei auf Neu, und klicken Sie auf Projekt.
Klicken Sie im Dialogfeld Neues Projekt im Bereich Projekttypen auf Visual Basic.
Wählen Sie im Dropdownmenü .NET Framework 3.5 aus.
Klicken Sie im Bereich Vorlagen auf Konsolenanwendung.
Geben Sie im Feld NameLinqToEntitiesConsoleApp ein.
Wählen Sie im Feld Speicherort einen Speicherort für die Projektdateien aus, und klicken Sie dann auf OK.
Klicken Sie im Menü Projekt auf Verweis hinzufügen, klicken Sie auf die Registerkarte .NET, klicken Sie auf die System.Data.Entity-Assembly und dann auf OK.
Fügen Sie der Quellcodedatei eine using-Direktive für den System.Data.Objects-Namespace hinzu.
Erstellen des AdventureWorks Sales-Modells
In dieser Aufgabe erstellen Sie mithilfe des Entitätsdatenmodell-Assistenten das AdventureWorks Sales-Modell und verweisen von Ihrem Projekt auf das Modell.
So erstellen Sie das AdventureWorks Sales-Modell und verweisen darauf
Klicken Sie im Menü Projekt auf Neues Element hinzufügen.
Wählen Sie im Dialogfeld Neues Element hinzufügen im Bereich Vorlagen die Option ADO.NET Entity Data Model aus. Nennen Sie das Modell AdventureWorksSalesModel, und klicken Sie dann auf Hinzufügen.
Wählen Sie im Dialogfeld Auswählen des Modellinhalts die Option Aus Datenbank generieren, und klicken Sie dann auf Weiter.
Wählen Sie im Fenster Wählen Sie Ihre Datenverbindung aus entweder eine bestehende AdventureWorks-Verbindung aus der Liste aus, oder erstellen Sie eine neue Verbindung mit einer SQL Server-Instanz, die über die AdventureWorks-Beispieldatenbank verfügt.
Speichern Sie die Einstellungen der Entitätsverbindung in App.Config als AdventureWorksEntities, und klicken Sie dann auf Weiter.
Entfernen Sie im Dialogfeld Datenbankobjekte auswählen die Markierungen aller Objekte, erweitern Sie Tabellen, und wählen Sie die folgenden Tabellenobjekte aus:
Address (Person)
Contact (Person)
Product (Production)
SalesOrderDetail (Sales)
SalesOrderHeader (Sales)
Nennen Sie den Modellnamespace AdventureSalesWorksModel, und klicken Sie dann auf Fertig stellen.
Die Ansicht Modellbrowser wird geöffnet und zeigt die Entitäten im AdventureWorks Sales-Modell an. Klicken Sie auf die Schaltfläche Speichern, und wählen Sie die Registerkarte Module1.vb aus, um zurück zum Quellcode zu navigieren.
Fügen Sie der Quelldatei eine Imports-Anweisung für AdventureWorksSalesModel hinzu.
Erstellen einer einfachen Abfrage
In diesem Schritt erstellen Sie eine Abfrage, die alle roten Produkte im AdventureWorks-Inventar zurückgibt. Die Abfragevariable speichert die Abfragebefehle nur dann, wenn die Abfrage so entwickelt wurde, dass sie eine Sequenz von Werten zurückgibt. Die tatsächliche Ausführung der Abfrage wird so lange verzögert, bis Sie die Abfragevariable in einer For Each-Schleife durchlaufen. Diese Methode wird als verzögerte Ausführung bezeichnet. Weitere Informationen finden Sie unter Abfrageausführung.
So erstellen Sie eine einfache Abfrage
- Geben Sie den folgenden Code in die
Main
-Methode ein, oder fügen Sie ihn ein.
Using AWEntities As New AdventureWorksEntities()
Dim products = AWEntities.Product
Dim query = From product In products _
Where product.Color = "Red" _
Select product
For Each product As Product In query
Console.WriteLine("Name: {0}", product.Name)
Console.WriteLine("Product number: {0}", product.ProductNumber)
Console.WriteLine("List price: ${0}", product.ListPrice)
Console.WriteLine("")
Next
End Using
' Prevent the console window from closing.
Console.WriteLine("Hit Enter...")
Console.Read()
Ausführen der Abfrage
In diesem Schritt führen Sie die Abfrage aus. Der im vorherigen Schritt erstellte Abfrageausdruck wird erst ausgewertet, wenn die Ergebnisse benötigt werden. Wenn die For Each-Iteration beginnt, wird die Abfrage des AdventureWorks Sales-Modells ausgeführt, und die Ergebnisse werden materialisiert.
So führen Sie die Abfrage aus
Drücken Sie F5, um die Anwendung im Debugmodus auszuführen.
Die Abfrageergebnisse werden im Konsolenfenster angezeigt.
Drücken Sie die EINGABETASTE im Konsolenfenster, um die Anwendung zu schließen.
Siehe auch
Aufgaben
Gewusst wie: Verwenden des Assistenten für Entity Data Model (Entity Framework)