LINQ - Objekte

LINQ to Objects bietet die Verwendung jeder LINQ-Abfrage, die IEnumerable <T> für den Zugriff auf speicherinterne Datensammlungen unterstützt, ohne dass ein LINQ-Provider (API) erforderlich ist, wie im Fall von LINQ to SQL oder LINQ to XML.

Einführung von LINQ in Objekte

Abfragen in LINQ to Objects geben Variablen vom Typ IEnumerable <T> zurück. Kurz gesagt, LINQ to Objects bietet einen neuen Ansatz für Sammlungen, da es früher wichtig war, lange Codierungen (für jede Schleife von großer Komplexität) zu schreiben, um Daten aus einer Sammlung abzurufen, die jetzt durch das Schreiben von deklarativem Code ersetzt wird, der die gewünschten Daten klar beschreibt das ist erforderlich, um abzurufen.

Es gibt auch viele Vorteile von LINQ to Objects gegenüber herkömmlichen foreach-Schleifen wie mehr Lesbarkeit, leistungsstarke Filterung, Gruppierungsfähigkeit, verbesserte Reihenfolge bei minimaler Anwendungscodierung. Solche LINQ-Abfragen sind auch kompakter und können ohne Änderungen oder mit nur geringen Änderungen auf andere Datenquellen übertragen werden.

Unten finden Sie ein einfaches Beispiel für LINQ to Objects -

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace LINQtoObjects {
   class Program {
      static void Main(string[] args) {
      
         string[] tools = { "Tablesaw", "Bandsaw", "Planer", "Jointer", "Drill", "Sander" };
         var list = from t in tools select t;

         StringBuilder sb = new StringBuilder();

         foreach (string s in list) {
            sb.Append(s + Environment.NewLine);
         }
		 
         Console.WriteLine(sb.ToString(), "Tools");
         Console.ReadLine();
      }
   }
}

In diesem Beispiel wird ein Array von Zeichenfolgen (Werkzeugen) als Sammlung von Objekten verwendet, die mit LINQ to Objects abgefragt werden sollen.

Objects query is:
var list = from t in tools select t;

Wenn der obige Code kompiliert und ausgeführt wird, ergibt sich das folgende Ergebnis:

Tablesaw
Bandsaw
Planer
Jointer
Drill
Sander

Abfragen in Speichersammlungen mit LINQ zu Objekten

C #

using System;
using System.Collections.Generic;
using System.Linq;

namespace LINQtoObjects {
   class Department {
      public int DepartmentId { get; set; }
      public string Name { get; set; }
   }

   class LinqToObjects {
      static void Main(string[] args) {
      
         List<Department> departments = new List<Department>();
			
         departments.Add(new Department { DepartmentId = 1, Name = "Account" });
         departments.Add(new Department { DepartmentId = 2, Name = "Sales" });
         departments.Add(new Department { DepartmentId = 3, Name = "Marketing" });

         var departmentList = from d in departments
                              select d;

         foreach (var dept in departmentList) {
            Console.WriteLine("Department Id = {0} , Department Name = {1}",
               dept.DepartmentId, dept.Name);
         }
		 
         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Imports System.Collections.Generic
Imports System.Linq

Module Module1

   Sub Main(ByVal args As String())

      Dim account As New Department With {.Name = "Account", .DepartmentId = 1}
      Dim sales As New Department With {.Name = "Sales", .DepartmentId = 2}
      Dim marketing As New Department With {.Name = "Marketing", .DepartmentId = 3}

      Dim departments As New System.Collections.Generic.List(Of Department)(New Department() {account, sales, marketing})

      Dim departmentList = From d In departments

      For Each dept In departmentList
         Console.WriteLine("Department Id = {0} , Department Name = {1}", dept.DepartmentId, dept.Name)
      Next

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
   End Sub

   Class Department
      Public Property Name As String
      Public Property DepartmentId As Integer
   End Class
   
End Module

Wenn der obige Code von C # oder VB kompiliert und ausgeführt wird, ergibt sich das folgende Ergebnis:

Department Id = 1, Department Name = Account
Department Id = 2, Department Name = Sales
Department Id = 3, Department Name = Marketing

Press any key to continue.