C#
[C#] EF Core - Fluent API 1:N 관계
범범조조
2023. 3. 19. 00:54
참조
소개
- 일반적으로 EF Core 에는 자동으로 구성할 수 있는 충분한 규칙이 포함되어 있으므로 1:N 관계를 구성할 필요가 없습니다.
- 그러나 쉬운 유지 관리를 위해 Fluent API 에 모든 EF 구성을 포함하기로 결정한 경우 Fluent API를 사용하여 1:N 관계를 구성할 수 있습니다.
예제
- EF Core를 사용하면 Fluent API를 사용하여 관계를 쉽게 구성할 수 있습니다.
- Grade Entity가 많은 Student Entity를 포함하는 다음 Student 및 Grade 클래스를 보시면 됩니다.
public class Student
{
public int Id { get; set; }
public string Name { get; set; }
public int CurrentGradeId { get; set; }
public Grade Grade { get; set; }
}
public class Grade
{
public int GradeId { get; set; }
public string GradeName { get; set; }
public string Section { get; set; }
public ICollection<Student> Students { get; set; }
}
- 아래와 같이 Context 클래스에서 OnModelCreating 메서드를 재정의하여 Fluent API를 사용하여 위 Entity에 대한 1:N 관계를 구성할 수 있습니다.
using Microsoft.EntityFrameworkCore;
namespace StudentApp.Data
{
public class SchoolContext : DbContext
{
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseNpgsql(@"Server=localhost;Database=JoBeomHee;Port=5432;User Id=JoBeomHee;Password=1234");
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Student>()
.HasOne<Grade>(s => s.Grade)
.WithMany(g => g.Students)
.HasForeignKey(s => s.CurrentGradeId);
}
public DbSet<Grade> Grades { get; set; }
public DbSet<Student> Students { get; set; }
}
}
- 위 예에서 다음 코드는 1:N 관계를 구성합니다.
modelBuilder.Entity<Student>()
.HasOne<Grade>(s => s.Grade)
.WithMany(g => g.Students)
.HasForeignKey(s => s.CurrentGradeId);
- 이제 데이터베이스에 반영하기 위해 마이그레이션 명령인 Add-Migration
및 update-database 를 실행합니다. - 마이그레이션이 정상적으로 실행 되었다면, 데이터베이스에는 아래와 같이 1:N 관계가 있는 2개의 Student, Grade 테이블이 생성된 것을 확인할 수 있습니다.
코드 관계 해석
- 첫째로, Student 또는 Grade 중 하나의 Entity Class로 구성을 시작해야 합니다.
- 따라서
modelBuilder.Entity<student>()
는 Student Entity로 시작합니다. - 두 번째로,
.HasOne<Grade>(s => s.Grade)
는 Student Entity에 Grade라는 Grade 유형 속성이 포함 되도록 지정합니다. - 세 번째로, 관계의 다른 쪽 끝인 Grade 엔티티를 구성해야 합니다.
.WithMany(g => g.Stduents)
는 Grade Entity 클래스에 많은 Student Entity가 포함되도록 지정합니다.- 여기서 WithMany는 컬렉션 탐색 속성을 유추합니다.
.HasForeignKey<int>(s => s.CurrentGradeId);
외래 키 속성 CurrentGradeId의 이름을 지정합니다.- 외래키 지정은 선택사항 입니다. 종속 클래스에 외래 키 Id 속성이 있는 경우에만 사용합니다.
728x90