LINQ-엔터티

ADO.NET Entity Framework의 일부인 LINQ to Entities는 LINQ to SQL보다 더 유연하지만 복잡성과 주요 기능 부족으로 인해 그다지 인기가 없습니다. 그러나 LINQ to Entities는 Oracle, MySQL 등과 같은 많은 데이터 공급자에서 데이터 쿼리를 용이하게하므로 SQL 서버 데이터베이스에서만 데이터 쿼리를 허용하는 LINQ to SQL의 제한이 없습니다.

또한 사용자가 LINQ to Entities를 통해 쿼리를 실행하기 위해 데이터 소스 컨트롤을 사용할 수 있고 추가 코딩없이 결과 바인딩을 용이하게한다는 점에서 ASP.Net의 주요 지원을 받았습니다.

LINQ to Entities는 이러한 이점 때문에 오늘날 데이터베이스에서 LINQ를 사용하기위한 표준 메커니즘이되었습니다. LINQ to Entities를 사용하면 쿼리 된 데이터 세부 정보를 변경하고 일괄 업데이트를 쉽게 커밋 할 수도 있습니다. LINQ to Entities에 대한 가장 흥미로운 사실은 SQL과 동일한 구문이 있고 Join, Select, OrderBy 등과 같은 표준 쿼리 연산자 그룹도 동일하다는 것입니다.

LINQ to Entities 쿼리 생성 및 실행 프로세스

  • 건설 ObjectQuery 인스턴스에서 ObjectContext (엔티티 연결)

  • 새로 생성 된 인스턴스를 사용하여 C # 또는 VB (Visual Basic)로 쿼리 작성

  • LINQ의 표준 쿼리 연산자와 LINQ 식을 명령 트리로 변환

  • 발생한 모든 예외를 클라이언트에 직접 전달하는 쿼리 실행

  • 모든 쿼리 결과를 클라이언트에 반환

ObjectContext 상호 작용을 가능하게하는 기본 클래스입니다. Entity Data Model즉, LINQ를 데이터베이스에 연결하는 브리지 역할을합니다. 여기서 명령 트리는 Entity 프레임 워크와의 호환성을 가진 쿼리 표현입니다.

반면에 Entity Framework는 실제로 Object Relational Mapper데이터베이스 테이블에 따라 비즈니스 개체 및 엔터티를 생성하고 생성, 업데이트, 삭제 및 읽기와 같은 다양한 기본 작업을 용이하게하는 개발자가 일반적으로 ORM으로 축약합니다. 다음 그림은 엔터티 프레임 워크 및 해당 구성 요소를 보여줍니다.

엔터티 모델과 함께 LINQ를 사용하는 ADD, UPDATE 및 DELETE의 예

먼저 아래 단계에 따라 엔티티 모델을 추가하십시오.

Step 1− 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 새 항목 추가를 클릭하면 아래와 같은 창이 열립니다. ADO.NET 엔터티 데이터 모델을 선택하고 이름을 지정하고 추가를 클릭합니다.

Step 2 − 선택 Generate from database.

Step 3 − 드롭 다운 메뉴에서 데이터베이스 연결을 선택합니다.

Step 4 − 모든 테이블을 선택합니다.

이제 다음 코드를 작성하십시오.

using DataAccess;
using System;
using System.Linq;

namespace LINQTOSQLConsoleApp {
   public class LinqToEntityModel {
      static void Main(string[] args) {

         using (LinqToSQLDBEntities context = new LinqToSQLDBEntities()) {
            //Get the List of Departments from Database
            var departmentList = from d in context.Departments
            select d;

            foreach (var dept in departmentList) {
               Console.WriteLine("Department Id = {0} , Department Name = {1}",
                  dept.DepartmentId, dept.Name);
            }

            //Add new Department
            DataAccess.Department department = new DataAccess.Department();
            department.Name = "Support";

            context.Departments.Add(department);
            context.SaveChanges();

            Console.WriteLine("Department Name = Support is inserted in Database");

            //Update existing Department
            DataAccess.Department updateDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 1);
            updateDepartment.Name = "Account updated";
            context.SaveChanges();

            Console.WriteLine("Department Name = Account is updated in Database");

            //Delete existing Department
            DataAccess.Department deleteDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 3);
            context.Departments.Remove(deleteDepartment);
            context.SaveChanges();

            Console.WriteLine("Department Name = Pre-Sales is deleted in Database");

            //Get the Updated List of Departments from Database
            departmentList = from d in context.Departments
            select d;

            foreach (var dept in departmentList) {
               Console.WriteLine("Department Id = {0} , Department Name = {1}",
                  dept.DepartmentId, dept.Name);
            }
         }

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.