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 필드를 제외합니다. 이렇게하면 응용 프로그램이 훨씬 빨라집니다.