LINQ 쿼리 식(C# 프로그래밍 가이드)
LINQ(Language-Integrated Query)는 C# 언어(또한 Visual Basic 및 잠재적으로 다른 모든 .NET 언어)에 대한 쿼리 기능의 직접 통합을 기반으로 하는 기술 집합의 이름입니다. LINQ를 사용하면 쿼리가 클래스, 메서드, 이벤트와 같은 고급 언어 구문이 됩니다.
쿼리를 작성하는 개발자에게 가장 많이 표시되는 LINQ의 "통합 언어" 부분은 쿼리 식입니다. 쿼리 식은 C# 3.0에서 소개된 선언적 쿼리 구문으로 작성됩니다. 쿼리 구문을 사용하면 최소한의 코드로 데이터 소스에 대해 복잡한 필터링, 정렬 및 그룹화 작업을 수행할 수 있습니다. 동일한 기본 쿼리 식 패턴을 사용하여 SQL 데이터베이스, ADO.NET 데이터 집합, .XML 문서 및 스트림, .NET 컬렉션의 데이터를 쿼리하고 변환합니다.
다음 예제에서는 전체 쿼리 작업을 보여 줍니다. 전체 작업에는 데이터 소스 만들기, 쿼리 식 정의 및 foreach 문으로 쿼리 실행이 포함됩니다.
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 + " ");
}
}
}
// Output: 97 92 81
C#의 LINQ 기본 사항에 대한 자세한 내용은 C#에서 LINQ 시작을 참조하십시오.
쿼리 식 개요
쿼리 식은 LINQ 사용 데이터 소스의 데이터를 쿼리 및 변환하는 데 사용할 수 있습니다. 예를 들어 단일 쿼리는 SQL 데이터베이스에서 데이터를 검색하고 XML 스트림을 출력으로 생성할 수 있습니다.
쿼리 식은 많은 익숙한 C# 언어 구문을 사용하므로 쉽게 익힐 수 있습니다. 자세한 내용은 C#에서 LINQ 시작을 참조하십시오.
컴파일러가 형식을 유추할 수 있으므로 대부분 명시적으로 형식을 제공할 필요는 없지만 쿼리 식의 변수는 모두 강력한 형식입니다. 자세한 내용은 LINQ 쿼리 작업의 형식 관계(C#)를 참조하십시오.
쿼리는 foreach 문에서 쿼리 변수를 반복할 때까지 실행되지 않습니다. 자세한 내용은 LINQ 쿼리 소개(C#)를 참조하십시오.
컴파일 타임에 쿼리 식은 C# 사양에 설정된 규칙에 따라 표준 쿼리 연산자 메서드로 변환됩니다. 쿼리 구문을 사용하여 표현할 수 있는 모든 쿼리는 메서드 구문으로도 표현할 수 있습니다. 그러나 대체로 쿼리 구문이 더 읽기 쉽고 간결합니다. 자세한 내용은 C# 언어 사양 및 표준 쿼리 연산자 개요를 참조하십시오.
일반적으로 LINQ 쿼리를 작성할 때는 가능한 한 쿼리 구문을 사용하고 필요한 경우에만 메서드 구문을 사용하는 것이 좋습니다. 두 형태 간에 의미 체계 또는 성능상의 차이는 없습니다. 쿼리 식이 메서드 식으로 작성된 동등한 식보다 읽기 쉽습니다.
Count``1 또는 Max 같은 일부 쿼리 작업에는 동등한 쿼리 식 절이 없으므로 메서드 호출로 표현해야 합니다. 다양한 방법으로 메서드 구문과 쿼리 구문을 결합할 수 있습니다. 자세한 내용은 LINQ의 쿼리 구문 및 메서드 구문(C#)를 참조하십시오.
쿼리가 적용되는 형식에 따라 쿼리 식을 식 트리나 대리자로 컴파일할 수 있습니다. IEnumerable 쿼리는 대리자로 컴파일되고 IQueryable 및 IQueryable 쿼리는 식 트리로 컴파일됩니다. 자세한 내용은 식 트리(C# 및 Visual Basic)를 참조하십시오.
다음 표에서는 일반적인 작업을 위한 쿼리 및 코드 예제에 대한 추가 정보를 제공하는 항목을 보여 줍니다.
항목 |
설명 |
---|---|
기본적인 쿼리 개념을 소개하고 C# 쿼리 구문의 예제를 제공합니다. |
|
몇 가지 기본적인 쿼리 식 형식의 예제를 제공합니다. |
|
잠재적 예외 throw 코드를 쿼리 식 외부로 이동하는 방법 및 시기를 보여 줍니다. |
|
select 문을 사용하여 여러 소스의 데이터를 새 형식으로 병합하는 방법을 보여 줍니다. |
|
group 절을 사용하는 다양한 방법을 보여 줍니다. |
|
중첩 그룹을 만드는 방법을 보여 줍니다. |
|
쿼리의 하위 식을 새 쿼리의 데이터 소스로 사용하는 방법을 보여 줍니다. |
|
스트리밍 데이터 소스에 대한 그룹화 작업을 수행할 수 있는 스레드로부터 안전한 표준 쿼리 연산자를 구현하는 방법을 보여 줍니다. |
|
동등 비교에 사용할 임의 개수의 값을 where 절에 제공하는 방법을 보여 줍니다. |
|
foreach 루프를 사용하지 않고도 쿼리 결과를 구체화하고 저장하는 방법을 보여 줍니다. |
|
메서드에서 쿼리 변수를 반환하는 방법 및 이러한 변수를 입력 매개 변수로 메서드에 전달하는 방법을 보여 줍니다. |
|
조건자 함수 종류를 기반으로 조인 작업을 수행하는 방법을 보여 줍니다. |
|
둘 이상의 일치하는 키를 기반으로 두 개의 소스를 조인하는 방법을 보여 줍니다. |
|
조인 작업으로 생성된 시퀀스를 정렬하는 방법을 보여 줍니다. |
|
LINQ에서 내부 조인을 수행하는 방법을 보여 줍니다. |
|
LINQ에서 그룹화된 조인을 생성하는 방법을 보여 줍니다. |
|
LINQ에서 왼쪽 우선 외부 조인을 생성하는 방법을 보여 줍니다. |
|
LINQ 쿼리에서 null 값을 처리하는 방법을 보여 줍니다. |