C#
[C#] EF Core 첫 번째 어플리케이션
범범조조
2023. 3. 15. 00:48
참고
소개
- Code-First 방식으로 EF Core 첫 번째 어플리케이션을 만들어 보도록 하겠습니다.
개발 환경
- 개발 환경은 다음과 같습니다.
- OS : Windows 11
- .NET Version : .NET 6*
- IDE : Visual Studio 2022
- Database : PostgreSQL
콘솔 프로그램 생성
- Visual Studio 2022 를 실행하고, C# 콘솔 프로그램을 하나 생성합니다.
Npgsql.EntityFrameworkCore NuGet Package 설치
- 저는 Database를 PostgreSQL을 사용하기 때문에, Npgsql.EntityFrameworkCore NuGet Package 를 설치 진행하였습니다.
모델 만들기
- Entity Framework에는 기본 데이터베이스와 통신 하기 위한 모델이 있어야 합니다.
- 도메인 클래스의 모양, 데이터 주석 및 Fluent API 구성을 기반으로 모델을 빌드합니다.
- EF 모델에는 개념적 모델, 저장소 모델 및 개념적 모델과 저장소 모델 간의 매핑의 세 부분이 포함 됩니다.
- 코드 우선 접근 방식에서는 EF는 도메인 클래스, 컨텍스트 클래스 및 구성을 기반으로 개념적 모델을 빌드합니다.
- EF Core는 사용하는 공급자를 기반으로 스토리지 모델 및 매핑을 빌드합니다.
- 예제를 위하여 Student, Course 2개의 모델을 생성하였습니다.
public class Student
{
public int StudentId { get; set; }
public string Name { get; set; }
}
public class Course
{
public int CourseId { get; set; }
public string CourseName { get; set; }
}
DBContext 생성
- 다음으로 DBContext를 파생하여 컨텍스트 클래스를 생성해야 합니다.
- 다음 SchoolContext.cs 클래스는 컨텍스트 클래스라고 합니다.
using Microsoft.EntityFrameworkCore;
namespace EFCoreSample
{
public class SchoolContext : DbContext
{
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseNpgsql(@"Server=localhost;Database=postgres;Port=5432;User Id=postgres;Password=postgres");
}
public DbSet<Student> Students { get; set; }
public DbSet<Course> Courses { get; set; }
}
}
마이그레이션 작업
- 앞서 Student, Course 관련하여 C# 코드로 클래스 작성을 완료 하였습니다.
- 이제는 실제로 해당 클래스들을 PostgreSQL 데이터베이스에 매핑하여 테이블 생성 할 수 있도록 마이그레이션 작업을 진행해야 합니다.
- 마이그레이션 작업 순서는 다음과 같습니다.
EntityFrameworkCore.Tools NuGet Package 설치
- Microsoft.EntityFrameworkCore.Tools NuGet Package 설치를 진행해야 합니다.
마이그레이션 명령어 입력
- Microsoft.EntityFrameworkCore.Tools NuGet Package 설치가 완료 되었으면, 다음 명령어를 실행하여 Migration 코드가 생성되도록 진행합니다.
- 해당 명령어를 실행하기 위해서는 Tools -> NuGet Package Manager -> Package Manager Console 을 실행하여 명령어를 입력합니다.
> Add-Migration InitialDatabase
- 위 명령어가 성공적으로 이루어 지면, 다음과 같이 Migration 파일이 생성됩니다.
- 이제 해당 정보를 PostgreSQL 데이터베이스에 Update 진행합니다.
- Update 명령어는 다음과 같습니다.
> Update-Database
PostgreSQL 테이블 확인
- 실제로 PostgreSQL 접속하여, postgres 데이터베이스 안에 Student, Course 2개의 테이블이 생성되었는지 확인 합니다.
- 확인 결과, 정상적으로 2개의 테이블이 생성된 것을 확인할 수 있습니다.
728x90