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...
더 나은 이해를 위해 위의 예를 단계별로 실행하는 것이 좋습니다.