Sie sind hier: Startseite | Wissen
BASTA 2015

Begriff Language Integrated Query
Abkürzung LINQ

 Zur Stichwortliste unseres Lexikons

Was ist Language Integrated Query?

Language Integrated Query (LINQ) ist eine allgemeine Such-/Abfragesprache, die seit dem .NET Framework 3.5 in der Sprachsyntax von C# 3.0 und Visual Basic 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:
  • LINQ to XSD
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
  • LINQ to ADS
http://www.codeplex.com/LINQtoAD
  • LINQ to LDAP
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
  • LINQ to Amazon
http://weblogs.asp.net/fmarguerie/archive/2006/06/26/Introducing-Linq-to-Amazon.aspx
  • LINQ to FlickR
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.FL_Zielort select c) .Skip(5) .Take(5);

Artikel in gedruckten Medien

  Die Datenbank-Konsole: LINQPad
 (DotNetPro - Das .NET-Magazin für Entwickler, 2014)
  Programmieren mit dem ADO.NET Entity Framework
 (Programmieren mit dem ADO.NET Entity Framework, 2011)

Querverweise zu anderen Begriffen im Lexikon

LINQ to ADO.NET
My
Datenbank
Visual Basic 9.0
.NET 3.5
Nhibernate
IntelliSense
Codeplex
Compiler
System.Diagnostics
Objektmenge
Service Pack
Objekt-Relationales Mapping
Java
Entwicklungsumgebung
LINQ-to-SQL
LINQ-to-Entities
LINQ-to-Dataset
.NET Framework 3.5
DataSet
PostgreSQL
Orcas
Oracle
ADO.NET Entity Framework

Beratung & Support:

Schulungen zu diesem Thema:

 Anfrage für eine individuelle Schulung zum Thema Language Integrated Query  Gesamter Schulungsthemenkatalog