Grundlegende Abfrageoperationen (Visual Basic)
Dieses Thema enthält eine kurze Einführung in Language-Integrated Query (LINQ)-Ausdrücke in Visual Basic und in einige der typischen Vorgänge bei einer Abfrage. Weitere Informationen finden Sie unter den folgenden Themen:
Einführung in LINQ in Visual Basic
Exemplarische Vorgehensweise: Schreiben von Abfragen in Visual Basic
Angeben der Datenquelle (From)
In einer LINQ-Abfrage ist der erste Schritt das Angeben der Datenquelle, für die eine Abfrage durchgeführt werden soll. Dadurch wechselt die From-Klausel in einer Abfrage immer zuerst. Abfrageoperatoren wählen aus und entstehende das Ergebnis auf dem Typ der Quelle.
Dim query = From cust In customers
' ...
Die From-Klausel gibt die Datenquelle, customers und die Bereichsvariable cust an. Die Bereichsvariable ist vergleichbar mit einer Schleifeniterationsvariablen, mit dem Unterschied, dass in einem Abfrageausdruck keine wirkliche Iteration stattfindet. Wenn die Abfrage ausgeführt wird, häufig durch Verwendung einer For Each-Schleife, dient die Bereichsvariable als Verweis auf jedes darauf folgende Element in customers. Da der Compiler den Typ von cust per Rückschluss ableiten kann, müssen Sie es nicht explizit angeben. Beispiele für Abfragen, die mit und ohne explizite Typisierung geschrieben werden, finden Sie unter Typbeziehungen in Abfrageoperationen (Visual Basic).
Weitere Informationen zur Verwendung der From-Klausel in Visual Basic finden Sie unter From-Klausel (Visual Basic).
Filtern von Daten (Where)
Die wahrscheinlich üblichste Abfrageoperation ist das Anwenden eines Filters in Form eines booleschen Ausdrucks. Die Abfrage gibt dann nur jene Elemente zurück, für die der Ausdruck den Wert true hat. Eine Where-Klausel wird verwendet, um die Filterung auszuführen. Der Filter gibt an, welche Elemente in der Datenquelle in der resultierenden Sequenz eingeschlossen werden sollen. Im folgenden Beispiel sind nur jene Kunden enthalten, die eine Adresse in London haben.
Dim londonCusts = From cust In customers
Where cust.City = "London"
' ...
Sie können logische Operatoren wie And and Or zum Kombinieren von Filterausdrücken in einer Where-Klausel verwenden. Um beispielsweise nur die Kunden zurückzugeben, die aus London stammen und den Namen Devon haben, verwenden Sie folgenden Code:
Where cust.City = "London" And cust.Name = "Devon"
Um Kunden aus London oder Paris zurückzugeben, verwenden Sie den folgenden Code:
Where cust.City = "London" Or cust.City = "Paris"
Weitere Informationen zur Verwendung der Where-Klausel in Visual Basic finden Sie unter Where-Klausel (Visual Basic).
Sortieren von Daten (Order By)
Es ist oft praktisch, zurückgegebene Daten in einer bestimmten Reihenfolge zu sortieren. Mit der Order By-Klausel können die Elemente in der zurückgegebenen Sequenz anhand eines bestimmten Felds oder anhand bestimmter Felder sortiert werden. Zum Beispiel sortiert die folgende Abfrage die Ergebnisse auf Grundlage der Name-Eigenschaft. Da Name eine Zeichenfolge ist, werden die zurückgegebenen Daten alphabetisch sortiert, von A bis Z.
Dim londonCusts1 = From cust In customers
Where cust.City = "London"
Order By cust.Name Ascending
' ...
Um die Ergebnisse in umgekehrter Reihenfolge zu sortieren (von Z bis A), verwenden Sie die Order By...Descending-Klausel. Der Standard ist Ascending, wenn weder Ascending noch Descending angegeben ist.
Weitere Informationen zur Verwendung der Order By-Klausel in Visual Basic finden Sie unter ORDER BY-Klausel (Visual Basic).
Auswählen von Daten (Select)
Die Select-Klausel gibt die Form und den Inhalt zurückgegebener Elemente an. Sie können beispielsweise angeben, ob Ihre Ergebnisse aus vollständigen Customer-Objekten bestehen, nur einer Customer-Eigenschaft, einer Teilmenge von Eigenschaften, einer Kombination von Eigenschaften aus verschiedenen Datenquellen oder einem neuen Ergebnistyp, der auf einer Berechnung basiert. Wenn die Select-Klausel ein anderes Ergebnis als eine Kopie des Quellelements zurückgibt, wird der Vorgang als Projektion bezeichnet.
Um eine Auflistung abzurufen, die aus vollständigen Customer-Objekten besteht, wählen Sie die Bereichsvariable selbst aus:
Dim londonCusts2 = From cust In customers
Where cust.City = "London"
Order By cust.Name Ascending
Select cust
Wenn die Customer-Instanz ein großes Objekt mit vielen Feldern ist und Sie nur den Namen abrufen möchten, können Sie cust.Name auswählen, wie im folgenden Beispiel gezeigt. Der lokale Typrückschluss erkennt, dass dies den Ergebnistyp aus einer Auflistung von Customer-Objekten in eine Auflistung von Zeichenfolgen ändert.
Dim londonCusts3 = From cust In customers
Where cust.City = "London"
Order By cust.Name Ascending
Select cust.Name
Um mehrere Felder aus der Datenquelle auszuwählen, haben Sie zwei Möglichkeiten:
Geben Sie in der Select-Klausel die Felder an, die Sie in das Ergebnis einschließen möchten. Der Compiler definiert einen anonymen Typ, der über diese Felder als Eigenschaften verfügt. Weitere Informationen finden Sie unter Anonyme Typen (Visual Basic).
Da die zurückgegebenen Elemente im folgenden Beispiel Instanzen eines anonymen Typs sind, können Sie auf den Typ an anderer Stelle im Code nicht durch den Namen verweisen. Der vom Compiler festgelegte Name für den Typ enthält Zeichen, die in normalem Visual Basic-Code nicht gültig sind. Im folgenden Beispiel sind die Elemente in der Auflistung, die von der Abfrage in londonCusts4 zurückgegeben werden, Instanzen eines anonymen Typs.
Dim londonCusts4 = From cust In customers Where cust.City = "London" Order By cust.Name Ascending Select Name = cust.Name, Phone = cust.Phone For Each londonCust In londonCusts4 Console.WriteLine(londonCust.Name & " " & londonCust.Phone) Next
- oder -
Definieren Sie einen benannten Typ, der die Felder enthält, die Sie in das Ergebnis einschließen möchten, und erstellen und initialisieren Sie die Instanzen des Typs in der Select-Klausel. Verwenden Sie diese Option nur, wenn Sie einzelne Ergebnisse außerhalb der Auflistung verwenden möchten, in der sie zurückgegeben werden, oder wenn Sie sie als Parameter in Methodenaufrufen übergeben müssen. Der Typ von londonCusts5 im folgenden Beispiel ist IEnumerable(Of NamePhone).
Public Class NamePhone Public Name As String Public Phone As String ' Additional class elements End Class
Dim londonCusts5 = From cust In customers Where cust.City = "London" Order By cust.Name Ascending Select New NamePhone With {.Name = cust.Name, .Phone = cust.Phone}
Weitere Informationen zur Verwendung der Select-Klausel in Visual Basic finden Sie unter Select-Klausel (Visual Basic).
Verknüpfen von Daten (Join und Group Join)
Sie können mehr als eine Datenquelle in der From-Klausel auf mehrere Weisen kombinieren. Der folgende Code verwendet beispielsweise zwei Datenquellen und kombiniert deren Eigenschaften indirekt im Ergebnis. Die Abfrage wählt Studierende aus, deren Nachnamen mit einem Vokal beginnen.
Dim vowels() As String = {"A", "E", "I", "O", "U"}
Dim vowelNames = From student In students, vowel In vowels
Where student.Last.IndexOf(vowel) = 0
Select Name = student.First & " " &
student.Last, Initial = vowel
Order By Initial
For Each vName In vowelNames
Console.WriteLine(vName.Initial & ": " & vName.Name)
Next
Hinweis
Sie können diesen Code mit der in Gewusst wie: Erstellen einer Liste von Elementen erstellten Liste von Studierenden ausführen.
Das Join-Schlüsselwort ist äquivalent zu einem INNER JOIN-Schlüsselwort in SQL. Es kombiniert zwei Auflistungen auf Grundlage von übereinstimmenden Schlüsselwerten in den beiden Auflistungen. Die Abfrage gibt alle oder nur einen Teil der Auflistungselemente zurück, die übereinstimmende Schlüsselwerte aufweisen. Im folgenden Code wird z. B. die Aktion des vorherigen impliziten Joins dupliziert.
Dim vowelNames2 = From student In students
Join vowel In vowels
On student.Last(0) Equals vowel
Select Name = student.First & " " &
student.Last, Initial = vowel
Order By Initial
Group Join kombiniert Auflistungen in eine einzelne hierarchische Auflistung, genau wie ein LEFT JOIN-Schlüsselwort in SQL. Weitere Informationen finden Sie unter Join-Klausel (Visual Basic) und unter Group Join-Klausel (Visual Basic).
Gruppieren von Daten (Group By)
Sie können eine Group By-Klausel hinzufügen, um die Elemente in einem Abfrageergebnis gemäß einem oder mehreren Feldern von Elementen zu gruppieren. Zum Beispiel werden mit dem folgenden Code Studierende anhand des Jahrgangs gruppiert.
Dim studentsByYear = From student In students
Select student
Group By year = student.Year
Into Classes = Group
For Each yearGroup In studentsByYear
Console.WriteLine(vbCrLf & "Year: " & yearGroup.year)
For Each student In yearGroup.Classes
Console.WriteLine(" " & student.Last & ", " & student.First)
Next
Next
Wenn Sie diesen Code mit der in Gewusst wie: Erstellen einer Liste von Elementen erstellten Liste der Studierenden ausführen, lautet die Ausgabe der For Each-Anweisung:
Jahr: Junior
Tucker, Michael
Garcia, Hugo
Garcia, Debra
Tucker, Lance
Jahr: Senior
Omelchenko, Svetlana
Osada, Michiko
Fakhouri, Fadi
Feng, Hanying
Adams, Terry
Jahr: Freshman (Student im ersten Jahr)
Mortensen, Sven
Garcia, Cesar
Mit der folgenden Codevariation werden die Jahrgänge sortiert und anschließend die Studierenden innerhalb des Jahrgangs nach Nachname.
Dim studentsByYear2 = From student In students
Select student
Order By student.Year, student.Last
Group By year = student.Year
Into Classes = Group
Weitere Informationen über Group By finden Sie unter GROUP BY-Klausel (Visual Basic).
Siehe auch
Referenz
Konzepte
Übersicht über Standardabfrageoperatoren
Grundlegende LINQ-Abfragevorgänge (C#)