Sie sind hier: Startseite | Wissen
Werbung
Begriff Language Integrated Query
Abkürzung LINQ
Eintrag zuletzt aktualisiert am 21.08.2015

 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:
http://blogs.msdn.com/xmlteam/archive/2007/06/05/linq-to-xsd-preview-alpha-0-2-to-go-with-orcas-beta-1.aspx
  • LINQ to ADO.NET Data Service
http://quickstarts.asp.net/3-5-extensions/adonetdataservice/NETClientLibrary.aspxhttp://www.codeplex.com/LINQtoADhttp://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
  • LINQ to Nhibernate
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.aspxhttp://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.FLFlueges where c.FL_Abflugort == "London" orderby c.FLZielort select c) .Skip(5) .Take(5);

Beratung & Support:

Schulungen zu diesem Thema:

 Language Integrated Query (LINQ)
 Neuerungen in C# 3.0 (Visual C# 2008)
 .NET 3.5-Crashkurs - Überblick über das .NET Framework 3.5 und Visual Studio 2008 für Umsteiger von .NET 2.0/3.0
 .NET 3.5-Update - Die Neuerungen in .NET Framework 3.5 und Visual Studio 2008 im Überblick
 C#-Basiswissen (Grundlagen der Programmiersprache C#)
 .NET-Überblick für .NET-Einsteiger und .NET-Entscheider (wahlweise für .NET und/oder .NET Core)
 Entity Framework Core 2.x/3.x (EF Core 2.x/3.x) - Änderungen und Neuerungen gegenüber Entity Framework 6.x
 .NET im Überblick
 .NET Akademie: Datenbankprogrammierung mit Entity Framework Core (3-Tages-Agenda des öffentlichen Seminars)
 Parallelprogrammierung mit .NET (Multi-Threading/Multi-Tasking) - mit C#/Visual Basic und/oder C++
 Entity Framework Core (EF Core) - Objekt-Relationales Mapping für .NET und .NET Core
 .NET-Klassenbibliothek (.NET Framework Class Library - FCL)
 NHibernate - Objekt-Relationales Mapping (ORM) mit .NET
 ADO.NET Entity Framework (EF) - Objekt-Relationales Mapping
 Combit List&Label für Softwareentwickler (Berichte/Reporting mit List&Label)
 Open Data Protocol (OData) mit WCF Data Services und/oder ASP.NET WebAPI und/oder RESTier
 Multithreading in .NET (System.Threading)
 ASP.NET Webforms-Crashkurs (3 Tage)
 IronPython (Python für .NET)
 Visual Basic .NET - Basiswissen
 ADO.NET Entity Framework (EF) Code-based Modelling (alias Code First/Code Only)
 XML-Programmierung mit .NET (System.Xml) - Basiswissen
 .NET und C# für Umsteiger von Java
 .NET für Einsteiger
 ADO.NET Entity Framework (EF) mit Oracle - Objekt-Relationales Mapping für Oracle-Datenbanken
 .NET 4.0-Update - Die Neuerungen in .NET Framework 4.0 und Visual Studio 2010 im Überblick
 Windows-Desktop-Anwendungen: Von den .NET- und C#-Grundlagen zu Windows Forms und Windows Presentation Foundation (WPF)
 ASP.NET Webforms (System.Web) - Datenzugriff
 .NET Framework 3.5 Service Pack 1 und Visual Studio 2008 Service Pack 1
 Neuerungen in .NET Core 3.0/3.1 gegenüber Version 2.x (inkl. ASP.NET Core, Entity Framework Core, WPF und Windows Forms)
 Anfrage für eine individuelle Schulung zum Thema Language Integrated Query;LINQ  Gesamter Schulungsthemenkatalog

Bücher zu diesem Thema:

 Datenbankprogrammierung mit .NET 4.0. Mit Visual Studio 2010 und SQL Server 2008 R2
 .NET 3.5
 Moderne Datenzugriffslösungen mit Entity Framework Core 1.1 und 2.0-Preview2 (Buchversion 1.4)
 Moderne Datenzugriffslösungen mit Entity Framework Core 1.1: Datenbankprogrammierung mit .NET/.NET Core und C# (gedruckte Ausgabe)
 Moderne Datenzugriffslösungen mit Entity Framework Core 1.1.1 und 2.0-Preview2: Datenbankprogrammierung mit .NET/.NET Core und C# (gedruckte Ausgabe)
 Moderne Datenzugriffslösungen mit Entity Framework Core 2.0/2.1 (Buchversion 5.x, Ebook PDF)
 Microsoft Visual C# 2010
 Moderne Datenzugriffslösungen mit Entity Framework Core 3.0 (Buchversion 6.x, Kindle)
 ASP.NET 4.0
 Moderne Datenzugriffslösungen mit Entity Framework Core 2.0 (Buchversion 4.x): Datenbankprogrammierung mit .NET/.NET Core und C# (gedruckte Ausgabe)
 Moderne Datenzugriffslösungen mit Entity Framework Core 1.1 (PDF)
 Modern Data Access with Entity Framework Core: Database Programming Using .NET, .NET Core, UWP, and Xamarin with C#
 Moderne Datenzugriffslösungen mit Entity Framework 6 (EBOOK - PDF, MOBI, EPUB)
 .NET 3.5 Crashkurs
 Moderne Datenzugriffslösungen mit Entity Framework Core 1.1.2 und 2.0-Preview2: Datenbankprogrammierung mit .NET/.NET Core und C# (PDF)
 Moderne Datenzugriffslösungen mit Entity Framework Core 5.0 (Buchversion 9.x, Kindle)
 Moderne Datenzugriffslösungen mit Entity Framework Core 5.0 (Buchversion 9.x, DRUCK)
 Effizienter Datenzugriff mit Entity Framework Core: Datenbankprogrammierung mit C# für .NET Framework, .NET Core und Xamarin
 Microsoft ASP.NET 3.5 mit Visual C# 2008 - Das Entwicklerbuch
 SQL Server 2008 R2: Das Programmierhandbuch. Inkl. ADO.NET 3.5, LINQ to Entities und LINQ to SQL
 Moderne Datenzugriffslösungen mit Entity Framework Core 5.0 (Buchversion 9.x, PDF)
 Moderne Datenzugriffslösungen mit Entity Framework Core 3.0 (Buchversion 6.x, Gedruckt)
 Moderne Datenzugriffslösungen mit Entity Framework Core 3.1 (Buchversion 8.x, Kindle)
 Moderne Datenzugriffslösungen mit Entity Framework 6 (gedruckte Ausgabe)
 Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0: Datenbankprogrammierung mit .NET/.NET Core und C# (gedruckte Ausgabe)
 Visual Basic 2010
 Microsoft ASP.NET 3.5 mit Visual Basic 2008 - Das Entwicklerbuch
 Datenbankprogrammierung mit .NET 4.5. Mit Visual Studio 2012 und SQL Server 2012
 Moderne Datenzugriffslösungen mit Entity Framework Core 3.0 (Buchversion 7.x, PDF)
 Moderne Datenzugriffslösungen mit Entity Framework Core 3.1 (Buchversion 8.x, DRUCK)
 Moderne Datenzugriffslösungen mit Entity Framework Core 2.0 (Buchversion 4.x): Datenbankprogrammierung mit .NET/.NET Core und C# (EBOOK - PDF)
 Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0: Datenbankprogrammierung mit .NET/.NET Core und C# (EBOOK - PDF)
 Programmieren mit dem ADO.NET Entity Framework
 Moderne Datenzugriffslösungen mit Entity Framework 6 (Kindle)
 Moderne Datenzugriffslösungen mit Entity Framework Core 3.1 (Buchversion 8.x, PDF)
 Alle unsere aktuellen Fachbücher