LINQ-개요
전 세계 개발자는 정의 된 경로가없고 SQL, 웹 서비스, XQuery 등과 같은 여러 기술을 마스터해야하기 때문에 데이터 쿼리에 항상 문제가 발생했습니다.
Visual Studio 2008에서 도입되고 Anders Hejlsberg가 설계 한 LINQ (Language Integrated Query)는 SQL, XML 등과 같은 쿼리 언어에 대한 지식 없이도 쿼리를 작성할 수 있습니다. LINQ 쿼리는 다양한 데이터 유형에 대해 작성 될 수 있습니다.
LINQ 쿼리의 예
씨#
using System;
using System.Linq;
class Program {
static void Main() {
string[] words = {"hello", "wonderful", "LINQ", "beautiful", "world"};
//Get only short words
var shortWords = from word in words where word.Length <= 5 select word;
//Print each word out
foreach (var word in shortWords) {
Console.WriteLine(word);
}
Console.ReadLine();
}
}
VB
Module Module1
Sub Main()
Dim words As String() = {"hello", "wonderful", "LINQ", "beautiful", "world"}
' Get only short words
Dim shortWords = From word In words _ Where word.Length <= 5 _ Select word
' Print each word out.
For Each word In shortWords
Console.WriteLine(word)
Next
Console.ReadLine()
End Sub
End Module
위의 C # 또는 VB 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.
hello
LINQ
world
LINQ 구문
LINQ에는 두 가지 구문이 있습니다. 이들은 다음과 같습니다.
Lamda (메소드) 구문
var longWords = words.Where( w ⇒ w.length > 10);
Dim longWords = words.Where(Function(w) w.length > 10)
쿼리 (이해력) 구문
var longwords = from w in words where w.length > 10;
Dim longwords = from w in words where w.length > 10
LINQ 유형
LINQ 유형은 아래에 간략하게 설명되어 있습니다.
- LINQ to 개체
- LINQ to XML (XLINQ)
- LINQ to DataSet
- LINQ to SQL (DLINQ)
- LINQ to 엔터티
위와 별도로 Microsoft의 병렬 LINQ 인 PLINQ라는 LINQ 유형도 있습니다.
.NET의 LINQ 아키텍처
LINQ에는 최상위 계층이 언어 확장으로 구성되고 아래쪽 계층이 일반적으로 IEnumerable <T> 또는 IQueryable <T> 제네릭 인터페이스를 구현하는 개체 인 데이터 원본으로 구성된 3 계층 아키텍처가 있습니다. 아키텍처는 아래와 같습니다.
쿼리 식
쿼리 식은 Select, Where 및 OrderBy와 같은 쿼리 연산자를 사용하여 SQL과 유사한 형식으로 표현되는 LINQ 쿼리 일뿐입니다. 쿼리 식은 일반적으로 "From"키워드로 시작합니다.
표준 LINQ 쿼리 연산자에 액세스하려면 기본적으로 System.Query 네임 스페이스를 가져와야합니다. 이러한 식은 C # 3.0 인 선언적 쿼리 구문 내에서 작성됩니다.
다음은 데이터 소스 생성, 쿼리 표현식 정의 및 쿼리 실행으로 구성된 전체 쿼리 작업을 보여주는 예입니다.
씨#
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Operators {
class LINQQueryExpressions {
static void Main() {
// Specify the data source.
int[] scores = new int[] { 97, 92, 81, 60 };
// Define the query expression.
IEnumerable<int> scoreQuery = from score in scores where score > 80 select score;
// Execute the query.
foreach (int i in scoreQuery) {
Console.Write(i + " ");
}
Console.ReadLine();
}
}
}
위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.
97 92 81
확장 방법
.NET 3.5에 도입 된 확장 메서드는 정적 클래스에서만 선언되며 개체에 사용자 지정 메서드를 포함하여 해당 클래스의 실제 멤버가되지 않고도 클래스를 확장하는 정확한 쿼리 작업을 수행 할 수 있습니다. 이것들은 또한 과부하 될 수 있습니다.
간단히 말해서 확장 메서드는 쿼리 식을 기존 메서드 호출 (객체 지향)로 변환하는 데 사용됩니다.
LINQ와 저장 프로 시저의 차이점
LINQ와 저장 프로 시저 간에는 다양한 차이점이 있습니다. 이러한 차이점은 아래에 설명되어 있습니다.
저장 프로시 저는 예상 실행 계획을 따르기 때문에 LINQ 쿼리보다 훨씬 빠릅니다.
저장 프로 시저에 비해 LINQ 쿼리를 실행하는 동안 런타임 오류를 피하는 것은 이전에 Visual Studio의 Intellisense 지원과 컴파일 시간 동안 전체 형식 검사가 있기 때문에 쉽습니다.
LINQ는 저장 프로 시저의 경우가 아닌 .NET 디버거를 사용하여 디버깅을 허용합니다.
LINQ는 다양한 유형의 데이터베이스에 대한 코드를 다시 작성해야하는 저장 프로 시저와 달리 여러 데이터베이스에 대한 지원을 제공합니다.
LINQ 기반 솔루션의 배포는 저장 프로 시저 집합의 배포에 비해 쉽고 간단합니다.
LINQ 필요
LINQ 이전에는 C #, SQL 및 두 가지를 결합하여 완전한 애플리케이션을 구성하는 다양한 API를 배우는 것이 필수적이었습니다. 따라서 이러한 데이터 소스와 프로그래밍 언어는 임피던스 불일치에 직면합니다. 짧은 코딩의 필요성이 느껴집니다.
다음은 LINQ가 등장하기 전에 데이터를 쿼리하는 동안 개발자가 얼마나 많은 다양한 기술을 사용했는지에 대한 예입니다.
SqlConnection sqlConnection = new SqlConnection(connectString);
SqlConnection.Open();
System.Data.SqlClient.SqlCommand sqlCommand = new SqlCommand();
sqlCommand.Connection = sqlConnection;
sqlCommand.CommandText = "Select * from Customer";
return sqlCommand.ExecuteReader (CommandBehavior.CloseConnection)
흥미롭게도 주요 코드 라인 중에서 쿼리는 마지막 두 줄에 의해서만 정의됩니다. LINQ를 사용하면 동일한 데이터 쿼리를 아래에 언급 된 다음과 같이 읽을 수있는 색상 코드 형식으로 매우 짧은 시간에 작성할 수 있습니다.
Northwind db = new Northwind(@"C:\Data\Northwnd.mdf");
var query = from c in db.Customers select c;
LINQ의 장점
LINQ는 많은 장점을 제공하며 그중 가장 중요한 것은 개발자가 선언적으로 표현할 수있는 강력한 표현력입니다. LINQ의 다른 장점 중 일부는 다음과 같습니다.
LINQ는 디자인 타임에 실수를 찾는 데 도움이되는 구문 강조 표시를 제공합니다.
LINQ는보다 정확한 쿼리를 쉽게 작성하는 것을 의미하는 IntelliSense를 제공합니다.
LINQ에서는 코드 작성이 훨씬 빠르기 때문에 개발 시간도 크게 단축됩니다.
LINQ는 C # 언어와의 통합으로 인해 쉽게 디버깅 할 수 있습니다.
계층 적 기능으로 인해 LINQ를 사용하면 두 테이블 간의 관계를 쉽게 볼 수 있으며이를 통해 더 짧은 시간에 여러 테이블을 조인하는 쿼리를 작성할 수 있습니다.
LINQ를 사용하면 단일 LINQ 구문을 사용하는 동시에 다양한 데이터 원본을 쿼리 할 수 있으며 이는 주로 단일 기반이 있기 때문입니다.
LINQ는 확장 가능하므로 LINQ에 대한 지식을 사용하여 새 데이터 원본 형식을 쿼리 할 수 있습니다.
LINQ는 여러 데이터 소스를 단일 쿼리로 결합하고 복잡한 문제를 디버깅하기 쉬운 짧은 쿼리 집합으로 분할하는 기능을 제공합니다.
LINQ는 SQL 데이터를 XML 데이터로 변환하는 것과 같이 한 데이터 형식을 다른 데이터 형식으로 쉽게 변환 할 수 있도록합니다.