Entity Framework-데이터베이스 우선 접근 방식
이 장에서는 Database First 접근 방식으로 엔터티 데이터 모델을 만드는 방법에 대해 알아 보겠습니다.
Database First Approach는 엔티티 데이터 모델에 대한 Code First 및 Model First 접근법에 대한 대안을 제공합니다. 프로젝트의 데이터베이스에서 모델 코드 (클래스, 속성, DbContext 등)를 생성하고 이러한 클래스는 데이터베이스와 컨트롤러 간의 링크가됩니다.
Database First Approach는 기존 데이터베이스에서 엔티티 프레임 워크를 생성합니다. Model First 접근 방식에서 사용한 것과 동일한 방식으로 모델 / 데이터베이스 동기화 및 코드 생성과 같은 다른 모든 기능을 사용합니다.
간단한 예를 들어 보겠습니다. 다음 이미지와 같이 3 개의 테이블이 포함 된 데이터베이스가 이미 있습니다.
Step 1 − DatabaseFirstDemo 이름으로 새 콘솔 프로젝트를 생성 해 보겠습니다.
Step 2 − 모델을 생성하려면 먼저 솔루션 탐색기에서 콘솔 프로젝트를 마우스 오른쪽 버튼으로 클릭하고 추가 → 새 항목…을 선택합니다.
Step 3 − 중간 창에서 ADO.NET 엔티티 데이터 모델을 선택하고 이름 필드에 DatabaseFirstModel 이름을 입력합니다.
Step 4 − 추가 버튼을 클릭하면 엔티티 데이터 모델 마법사 대화 상자가 시작됩니다.
Step 5 − 데이터베이스에서 EF Designer를 선택하고 다음 버튼을 클릭합니다.
Step 6 − 기존 데이터베이스를 선택하고 다음을 클릭합니다.
Step 7 − Entity Framework 6.x를 선택하고 다음을 클릭합니다.
Step 8 − 포함하려는 모든 테이블보기 및 저장 프로 시저를 선택하고 마침을 클릭합니다.
엔티티 모델 및 POCO 클래스가 데이터베이스에서 생성되는 것을 볼 수 있습니다.
이제 program.cs 파일에 다음 코드를 작성하여 데이터베이스에서 모든 학생을 검색해 보겠습니다.
using System;
using System.Linq;
namespace DatabaseFirstDemo {
class Program {
static void Main(string[] args) {
using (var db = new UniContextEntities()) {
var query = from b in db.Students
orderby b.FirstMidName select b;
Console.WriteLine("All All student in the database:");
foreach (var item in query) {
Console.WriteLine(item.FirstMidName +" "+ item.LastName);
}
Console.WriteLine("Press any key to exit...");
Console.ReadKey();
}
}
}
}
위의 프로그램이 실행되면 다음과 같은 출력을 받게됩니다.
All student in the database:
Ali Khan
Arturo finand
Bill Gates
Carson Alexander
Gytis Barzdukas
Laura Norman
Meredith Alonso
Nino Olivetto
Peggy Justice
Yan Li
Press any key to exit...
위의 프로그램이 실행되면 이전에 데이터베이스에 입력 된 모든 학생의 이름을 볼 수 있습니다.
더 나은 이해를 위해 위의 예를 단계별로 실행하는 것이 좋습니다.