Entity Framework-프로젝션 쿼리
LINQ to 엔터티
LINQ to Entities를 이해하는 데 가장 중요한 개념 중 하나는 선언적 언어라는 것입니다. 정보를 얻는 방법보다는 필요한 정보를 정의하는 데 중점을 둡니다.
즉, 데이터베이스 액세스와 같은 작업을 수행하는 데 필요한 기본 코드를 파악하는 데 필요한 시간을 줄이고 데이터 작업에 더 많은 시간을 할애 할 수 있습니다.
선언적 언어가 실제로 개발자의 제어를 제거하지는 않지만 개발자가 중요한 것에주의를 집중하는 데 도움이된다는 점을 이해하는 것이 중요합니다.
LINQ to Entities 필수 키워드
LINQ 쿼리를 만드는 데 사용되는 기본 키워드를 아는 것이 중요합니다. 기억해야 할 키워드는 몇 개 뿐이지 만 다양한 방법으로 조합하여 특정 결과를 얻을 수 있습니다. 다음 목록은 이러한 기본 키워드를 포함하고 각 키워드에 대한 간단한 설명을 제공합니다.
Sr. No. | 키워드 및 설명 |
---|---|
1 | Ascending 정렬 작업이 범위의 가장 작은 (또는 가장 낮은) 요소에서 범위의 가장 높은 요소까지 발생하도록 지정합니다. 이것은 일반적으로 기본 설정입니다. 예를 들어, 알파벳 정렬을 수행 할 때 정렬은 A에서 Z까지의 범위입니다. |
2 | By 그룹화를 구현하는 데 사용되는 필드 또는 표현식을 지정합니다. 필드 또는 식은 그룹화 작업을 수행하는 데 사용되는 키를 정의합니다. |
삼 | Descending 정렬 작업이 범위의 가장 큰 (또는 가장 높은) 요소에서 범위의 가장 낮은 요소까지 발생하도록 지정합니다. 예를 들어 알파벳 정렬을 수행 할 때 정렬은 Z에서 A까지의 범위에 있습니다. |
4 | Equals 조인 문의 왼쪽 및 오른쪽 절 사이에서 기본 컨텍스트 데이터 소스를 보조 컨텍스트 데이터 소스에 조인하는 데 사용됩니다. equals 키워드의 왼쪽에있는 필드 또는 표현식은 기본 데이터 소스를 지정하고 equals 키워드의 오른쪽에있는 필드 또는 표현식은 보조 데이터 소스를 지정합니다. |
5 | From 필요한 정보를 얻는 데 사용되는 데이터 소스를 지정하고 범위 변수를 정의합니다. 이 변수는 루프에서 반복에 사용되는 변수와 동일한 목적을 갖습니다. |
6 | Group 지정한 키 값을 사용하여 출력을 그룹으로 구성합니다. 여러 그룹 절을 사용하여 여러 수준의 출력 구성을 만듭니다. 그룹 절의 순서는 그룹화 순서에서 특정 키 값이 나타나는 깊이를 결정합니다. 이 키워드를 by와 결합하여 특정 컨텍스트를 만듭니다. |
7 | In 여러 가지 방법으로 사용됩니다. 이 경우 키워드는 쿼리에 사용되는 컨텍스트 데이터베이스 소스를 결정합니다. 조인으로 작업 할 때 조인에 사용되는 각 컨텍스트 데이터베이스 소스에 대해 in 키워드가 사용됩니다. |
8 | Into 조인, 그룹 및 선택과 같은 LINQ 쿼리 절에 대한 참조로 사용할 수있는 식별자를 지정합니다. |
9 | Join 마스터 / 세부 사항 설정과 같이 두 개의 관련 데이터 원본에서 단일 데이터 원본을 만듭니다. 조인은 내부 조인을 기본값으로 사용하여 내부, 그룹 또는 왼쪽-외부 조인을 지정할 수 있습니다. msdn.microsoft.com 에서 조인에 대해 자세히 알아볼 수 있습니다. |
10 | Let 쿼리 식에 하위 식 결과를 저장하는 데 사용할 수있는 범위 변수를 정의합니다. 일반적으로 범위 변수는 추가 열거 출력을 제공하거나 쿼리의 효율성을 높이는 데 사용됩니다 (문자열의 소문자 값 찾기와 같은 특정 작업을 한 번 이상 수행 할 필요가 없도록). |
11 | On 조인을 구현하는 데 사용되는 필드 또는 식을 지정합니다. 필드 또는 식은 두 컨텍스트 데이터 원본에 공통적 인 요소를 정의합니다. |
12 | Orderby 질의에 대한 정렬 순서를 만듭니다. 오름차순 또는 내림차순 키워드를 추가하여 정렬 순서를 제어 할 수 있습니다. 여러 orderby 절을 사용하여 여러 수준의 정렬을 만듭니다. orderby 절의 순서는 정렬식이 처리되는 순서를 결정하므로 다른 순서를 사용하면 출력이 달라집니다. |
13 | Where LINQ가 데이터 소스에서 검색해야하는 항목을 정의합니다. 하나 이상의 부울 식을 사용하여 검색 할 항목의 세부 사항을 정의합니다. 부울 표현식은 && (AND) 및 ||를 사용하여 서로 분리됩니다. (OR) 연산자. |
14 | Select 반환 할 정보를 지정하여 LINQ 쿼리의 출력을 결정합니다. 이 문은 반복 프로세스 중에 LINQ가 반환하는 요소의 데이터 형식을 정의합니다. |
투사
프로젝션 쿼리는 데이터베이스에서 특정 필드 만 검색하여 애플리케이션의 효율성을 향상시킵니다.
데이터가 있으면 출력하기 전에 데이터를 형성하기 위해 필요에 따라 데이터를 프로젝션하거나 필터링 할 수 있습니다.
모든 LINQ to Entities 식의 주요 작업은 데이터를 가져와 출력으로 제공하는 것입니다.
이 장의 "LINQ to Entities 쿼리 개발"섹션에서는이 기본 작업을 수행하는 기술을 보여줍니다.
학생 목록을 검색 할 다음 코드를 살펴 보겠습니다.
using (var context = new UniContextEntities()) {
var studentList = from s in context.Students select s;
foreach (var student in studentList) {
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
}
}
단일 개체
단일 학생 객체를 검색하려면 시퀀스의 첫 번째 요소를 반환하는 First () 또는 FirstOrDefault 열거 가능한 메서드를 사용할 수 있습니다. First와 FirstOrDefault의 차이점은 제공된 기준에 대한 결과 데이터가 없으면 First ()가 예외를 던지고 결과 데이터가 없으면 FirstOrDefault ()가 기본값 null을 반환한다는 것입니다. 아래 코드 스 니펫에서 목록의 첫 번째 학생은 이름이 Ali 인 학생을 검색합니다.
using (var context = new UniContextEntities()) {
var student = (from s in context.Students where s.FirstMidName
== "Ali" select s).FirstOrDefault<Student>();
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
}
Single () 또는 SingleOrDefault를 사용하여 시퀀스의 특정 단일 요소를 반환하는 단일 학생 객체를 가져올 수도 있습니다. 다음 예에서는 ID가 2 인 단일 학생이 검색됩니다.
using (var context = new UniContextEntities()) {
var student = (from s in context.Students where s.ID
== 2 select s).SingleOrDefault<Student>();
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
Console.ReadKey();
}
개체 목록
이름이 Ali 인 학생 목록을 검색하려면 ToList () 열거 가능한 메서드를 사용할 수 있습니다.
using (var context = new UniContextEntities()) {
var studentList = (from s in context.Students where s.FirstMidName
== "Ali" select s).ToList();
foreach (var student in studentList) {
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
}
Console.ReadKey();
}
주문
특정 순서로 데이터 / 목록을 검색하려면 orderby 키워드를 사용할 수 있습니다. 다음 코드에서 학생의 스 니펫 목록은 오름차순으로 검색됩니다.
using (var context = new UniContextEntities()) {
var studentList = (from s in context.Students orderby
s.FirstMidName ascending select s).ToList();
foreach (var student in studentList) {
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
}
Console.ReadKey();
}
표준 대 프로젝션 Entity Framework 쿼리
ID, FirstMidName, LastName 및 EnrollmentDate가 포함 된 Student 모델이 있다고 가정 해 보겠습니다. 학생 목록을 반환하려면 표준 쿼리가 모든 필드를 반환합니다. 그러나 ID, FirstMidName 및 LastName 필드가 포함 된 학생 목록 만 얻으려는 경우. 프로젝션 쿼리를 사용해야하는 곳입니다. 다음은 프로젝션 쿼리의 간단한 예입니다.
using (var context = new UniContextEntities()) {
var studentList = from s in context.Students
orderby s.FirstMidName ascending
where s.FirstMidName == "Ali"
select new {s.ID, s.FirstMidName, s.LastName};
foreach (var student in studentList) {
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
}
Console.ReadKey();
}
위의 프로젝션 쿼리는 EnrollmentDate 필드를 제외합니다. 이렇게하면 응용 프로그램이 훨씬 빨라집니다.