Entity Framework-모델 우선 접근 방식

이 장에서는 Model First라고하는 워크 플로를 사용하여 디자이너에서 엔터티 데이터 모델을 만드는 방법을 알아 봅니다.

  • Model First는 데이터베이스가 아직 존재하지 않는 새 프로젝트를 시작할 때 유용합니다.

  • 모델은 EDMX 파일에 저장되며 Entity Framework Designer에서보고 편집 할 수 있습니다.

  • Model First에서는 Entity Framework 디자이너에서 모델을 정의한 다음 SQL을 생성하여 모델과 일치하는 데이터베이스 스키마를 만든 다음 SQL을 실행하여 데이터베이스에 스키마를 만듭니다.

  • 애플리케이션에서 상호 작용하는 클래스는 EDMX 파일에서 자동으로 생성됩니다.

다음은 Model First 접근 방식을 사용하여 새 콘솔 프로젝트를 만드는 간단한 예입니다.

Step 1 − Visual Studio를 열고 파일 → 새로 만들기 → 프로젝트를 선택합니다.

Step 2 − 왼쪽 창에서 설치됨 → 템플릿 → Visual C # → Windows를 선택한 다음 가운데 창에서 콘솔 응용 프로그램을 선택합니다.

Step 3 − 이름 필드에 EFModelFirstDemo를 입력합니다.

Step 4 − 모델을 생성하려면 먼저 솔루션 탐색기에서 콘솔 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 추가 → 새 항목…을 선택합니다.

다음 대화 상자가 열립니다.

Step 5 − 중간 창에서 ADO.NET 엔티티 데이터 모델을 선택하고 이름 필드에 ModelFirstDemoDB 이름을 입력합니다.

Step 6 − 추가 버튼을 클릭하면 엔티티 데이터 모델 마법사 대화 상자가 시작됩니다.

Step 7− 빈 EF 디자이너 모델을 선택하고 다음 버튼을 클릭합니다. Entity Framework Designer가 빈 모델로 열립니다. 이제 항목, 속성 및 연결을 모델에 추가 할 수 있습니다.

Step 8− 디자인 화면을 마우스 오른쪽 버튼으로 클릭하고 속성을 선택합니다. 속성 창에서 엔터티 컨테이너 이름을 ModelFirstDemoDBContext로 변경합니다.

Step 9 − 디자인 화면을 마우스 오른쪽 버튼으로 클릭하고 새로 추가 → 엔티티…를 선택합니다.

다음 이미지와 같이 엔티티 추가 대화 상자가 열립니다.

Step 10 − 엔티티 이름으로 Student를 입력하고 속성 이름으로 Student Id를 입력하고 Ok를 클릭합니다.

Step 11 − 디자인 화면에서 새 엔티티를 마우스 오른쪽 버튼으로 클릭하고 새로 추가 → 스칼라 속성을 선택하고 속성 이름으로 이름을 입력합니다.

Step 12 − FirstName을 입력 한 다음 LastName 및 EnrollmentDate와 같은 또 다른 두 개의 스칼라 속성을 추가합니다.

Step 13 − 위에서 언급 한 모든 단계를 수행하여 엔터티 과정 및 등록을 두 개 더 추가하고 다음 단계와 같이 일부 Scalar 속성도 추가합니다.

Step 14 − Visual Designer에는 세 개의 엔티티가 있습니다. 이들 사이에 연관성 또는 관계를 추가해 보겠습니다.

Step 15 − 디자인 화면을 마우스 오른쪽 버튼으로 클릭하고 새로 추가 → 연결…을 선택합니다.

Step 16 − 관계의 한쪽 끝은 하나의 다중성을 가진 학생을 가리키고 다른 끝은 다중성이 많은 등록을 가리 킵니다.

Step 17 − 이것은 학생이 많은 등록을 가지고 있고 등록이 한 학생에 속함을 의미합니다.

Step 18 − '게시'항목에 외래 키 속성 추가 상자가 선택되어 있는지 확인하고 확인을 클릭합니다.

Step 19 − 마찬가지로 과정과 등록 사이에 하나 이상의 연결을 추가합니다.

Step 20 − 데이터 모델은 엔티티 간의 연관성을 추가 한 후 다음 화면과 같습니다.

이제 데이터베이스를 생성하고 데이터를 읽고 쓰는 데 사용할 수있는 간단한 모델이 있습니다. 계속해서 데이터베이스를 생성하겠습니다.

Step 1 − 디자인 화면을 마우스 오른쪽 버튼으로 클릭하고 모델에서 데이터베이스 생성…을 선택합니다.

Step 2 − 새 연결…을 클릭하여 기존 데이터베이스를 선택하거나 새 연결을 생성 할 수 있습니다.

Step 3 − 새 데이터베이스를 생성하려면 New Connection…을 클릭합니다.

Step 4 − 서버 이름과 데이터베이스 이름을 입력합니다.

Step 5 − 다음을 클릭합니다.

Step 6− 마침을 클릭합니다. 그러면 프로젝트에 * .edmx.sql 파일이 추가됩니다. .sql 파일을 열고 Visual Studio에서 DDL 스크립트를 실행 한 다음 마우스 오른쪽 단추를 클릭하고 실행을 선택할 수 있습니다.

Step 7 − 데이터베이스에 연결하기 위해 다음 대화 상자가 표시됩니다.

Step 8 − 성공적으로 실행되면 다음 메시지가 표시됩니다.

Step 9 − 서버 탐색기로 이동하면 지정된 세 개의 테이블로 데이터베이스가 생성 된 것을 볼 수 있습니다.

다음으로 DbContext API를 사용하는 코드를 생성하기 위해 모델을 교체해야합니다.

Step 1 − EF 디자이너에서 모델의 빈 곳을 마우스 오른쪽 버튼으로 클릭하고 코드 생성 항목 추가…를 선택합니다.

다음 새 항목 추가 대화 상자가 열립니다.

Step 2 − 가운데 창에서 EF 6.x DbContext Generator를 선택하고 이름 필드에 ModelFirstDemoModel을 입력합니다.

Step 3 − 솔루션 탐색기에서 ModelFirstDemoModel.Context.tt 및 ModelFirstDemoModel.tt 템플릿이 생성 된 것을 볼 수 있습니다.

ModelFirstDemoModel.Context는 DbCcontext 및 쿼리에 사용할 수있는 개체 집합 (예 : 컨텍스트, 학생 및 과정 등)을 생성합니다.

다른 템플릿은 Student, Courses 등의 모든 유형을 다룹니다. 다음은 엔티티 모델에서 자동으로 생성되는 Student 클래스입니다.

다음은 데이터베이스에서 일부 데이터를 입력하고 검색하는 C # 코드입니다.

using System;
using System.Linq;

namespace EFModelFirstDemo {

   class Program {

      static void Main(string[] args) {

         using (var db = new ModelFirstDemoDBContext()) {

            // Create and save a new Student

            Console.Write("Enter a name for a new Student: ");
            var firstName = Console.ReadLine();

            var student = new Student {
               StudentID = 1,
               FirstName = firstName
            };
				
            db.Students.Add(student);
            db.SaveChanges();
				
            var query = from b in db.Students
               orderby b.FirstName select b;

            Console.WriteLine("All student in the database:");

            foreach (var item in query) {
               Console.WriteLine(item.FirstName);
            }

            Console.WriteLine("Press any key to exit...");
            Console.ReadKey();
         }
      }
   }
}

위의 코드가 실행되면 다음과 같은 출력을 받게됩니다.

Enter a name for a new Student:
Ali Khan
All student in the database:
Ali Khan
Press any key to exit...

더 나은 이해를 위해 위의 예를 단계별로 실행하는 것이 좋습니다.