Language Integrated Query (LINQ)
Eintrag zuletzt aktualisiert am: 26.08.2022
Language Integrated Query (LINQ) ist eine allgemeine Such-/Abfragesprache, die seit dem
.NET Framework 3.5 (erschienen im Jahr 2007) in der Sprachsyntax in C# (seit Version 3.0) und Visual Basic (seit Version 9.0) verankert ist.
Language Integrated Query (LINQ) ist SQL-ähnlich, wird jedoch anders als klassische SQL-Befehle vom Sprachcompiler nicht als Zeichenkette, sondern als kompilierbare Anweisung betrachtet. Die Sprachen wurden dafür um Schlüsselwörter wie select, from, where, orderby, groupby usw. erweitert. Die kompilierten Abfragen können zur Laufzeit durch LINQ-Provider auf ganz unterschiedliche Datenspeicher ausgeführte werden. Neben
Datenbanken sind Abfragen auch auf
Objektmengen im Hauptspeicher, XML-Dokumente, Excel-Tabellen, SAP-Systeme und Websites wie Amazon,
Google und Twitter möglich. Der jeweilige LINQ-Provider implementiert dabei die Umsetzung von LINQ in die vom jeweiligen Datenspei-cher verwendete Abfragesprache. Damit bietet LINQ eine einheitliche Abfragesyntax für zahlreiche hete-rogene Datenspeicher verbunden mit dem weiteren Vorteil, dass der Spachkompiler die Syntax prüfen kann.
Microsoft bietet in .NET selbst die Möglichkeit zur Abfrage von .NET-
Objektmengen (LINQ to Objects), relationalen
Datenbanken (
LINQ-to-SQL und
LINQ-to-Entities),
DataSets (LINQ-to-
DataSet) und XML-Daten (LINQ-to-XML).
Bewertung
LINQ versteht sich als Vereinheitlichung unterschiedlichster Abfragesprachen wie z.B. SQL, Xpath, Xquery, etc. Der große Vorteil von LINQ ist, dass die Sprachkompiler die Syntax prüfen können und die
Entwicklungsumgebung IntelliSense-Unterstützung anbieten kann. Dies ist mit "externen" Suchsprachen, die der
Compiler nur als Zeichenkette sieht, nicht möglich.
Geschichte
Angekündigt: 13.9.2005 (
PDC 2005)
Alpha-Version verfügbar ab: 13.9.2005
Beta1-Version verfügbar ab: 19.5.2007
Erscheinungstermin: 19.11.2007
LINQ-Provider im .NET Framework seit .NET 3.5
LINQ unterteilt sich in die Gebiete:
LINQ to
DataSet
LINQ to SQL (früher: Dlinq) -->
Objekt-Relationales Mapping
LINQ to XML (früher: Xlinq)
LINQ to Objects
Zusätzlich LINQ-Provider im .NET Framework seit .NET 3.5 Service Pack 1
LINQ to Entities -->
ADO.NET Entity Framework
LINQ to
ADO.NET Data Service
Andere Anbieter/Projekte
Die folgende
Liste zeigt Links zu weiteren LINQ-Providern:
http://blogs.msdn.com/xmlteam/archive/2007/06/05/linq-to-xsd-preview-alpha-0-2-to-go-with-orcas-beta-1.aspx
http://quickstarts.asp.net/3-5-extensions/adonetdataservice/NETClientLibrary.aspx
http://www.codeplex.com/LINQtoAD
http://www.hookedonlinq.com/LINQ2LDAP.ashx- LINQ to VOA (kommerziell)
http://www.vanatec.com/en/product-information/linq2sql- LINQ to Genome (kommerziell)
http://www.genom-e.com/Default.aspx?tabid=227
http://www.hookedonlinq.com/LINQToNHibernate.ashx
http://weblogs.asp.net/fmarguerie/archive/2006/06/26/Introducing-Linq-to-Amazon.aspx
http://spellcoder.com/blogs/bashmohandes/archive/2007/04/08/6552.aspx
http://code2code.net/DB_Linq/
http://xircles.codehaus.org/projects/quaere
Beispiel: LINQ to Objects (C#)
var x =
from p in
System.Diagnostics.Process.GetProcesses()
where p.WorkingSet64 < 500000
select new { p.ProcessName, p.WorkingSet64 };
Beispiel: LINQ to SQL (C#)
var x =
(from c in db.FL
Flueges where c.FL_Abflugort == "London" orderby c.FLZielort select c) .Skip(5) .Take(5);