Entity Framework-시드 데이터베이스

Entity Framework에서 Seed는 EF 4.1에 도입되었으며 데이터베이스 이니셜 라이저와 함께 작동합니다. 일반적인 아이디어Seed MethodCode First에 의해 생성되거나 마이그레이션에 의해 발전된 데이터베이스로 데이터를 초기화하는 것입니다. 이 데이터는 종종 테스트 데이터이지만 알려진 학생, 코스 등의 목록과 같은 참조 데이터 일 수도 있습니다. 데이터가 초기화되면 다음을 수행합니다.

  • 대상 데이터베이스가 이미 존재하는지 확인합니다.
  • 그렇다면 현재 Code First 모델은 데이터베이스의 메타 데이터에 저장된 모델과 비교됩니다.
  • 현재 모델이 데이터베이스의 모델과 일치하지 않으면 데이터베이스가 삭제됩니다.
  • 데이터베이스가 삭제되었거나 처음에 존재하지 않은 경우 생성됩니다.
  • 데이터베이스가 생성 된 경우 이니셜 라이저 Seed 메서드가 호출됩니다.

Seed 메서드는 데이터베이스 컨텍스트 개체를 입력 매개 변수로 사용하고 메서드의 코드는 해당 개체를 사용하여 데이터베이스에 새 엔터티를 추가합니다. 데이터베이스에 데이터를 시드하려면 Seed 메서드를 재정의해야합니다. 일부 기본 데이터가 내부 클래스의 데이터베이스로 시작되는 다음 예제를 살펴 보겠습니다.

private class UniDBInitializer<T> : DropCreateDatabaseAlways<MyContext> {

   protected override void Seed(MyContext context) {

      IList<Student> students = new List<Student>();

      students.Add(new Student() {
         FirstMidName = "Andrew", 
         LastName = "Peters", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      });

      students.Add(new Student() {
         FirstMidName = "Brice", 
         LastName = "Lambson", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      });

      students.Add(new Student() {
         FirstMidName = "Rowan", 
         LastName = "Miller", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      });

      foreach (Student student in students)
      context.Students.Add(student);
      base.Seed(context);
   }
}

위 코드에서는 student 테이블이 초기화됩니다. 다음 코드와 같이 컨텍스트 클래스에서이 DB 이니셜 라이저 클래스를 설정해야합니다.

public MyContext() : base("name=MyContextDB") {
   Database.SetInitializer<MyContext>(new UniDBInitializer<MyContext>());
}

다음은 DB 이니셜 라이저 클래스도 포함하는 MyContext 클래스의 전체 클래스 구현입니다.

public class MyContext : DbContext {

   public MyContext() : base("name=MyContextDB") {
      Database.SetInitializer<MyContext>(new UniDBInitializer<MyContext>());
   }

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
	
   private class UniDBInitializer<T> : DropCreateDatabaseAlways<MyContext> {

      protected override void Seed(MyContext context) {

         IList<Student> students = new List<Student>();
			
         students.Add(new Student() {
            FirstMidName = "Andrew", 
            LastName = "Peters", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString()) 
         });

         students.Add(new Student() {
            FirstMidName = "Brice", 
            LastName = "Lambson", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         students.Add(new Student() {
            FirstMidName = "Rowan", 
            LastName = "Miller", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         foreach (Student student in students)
         context.Students.Add(student);
         base.Seed(context);
      }
   } 
}

위의 예제를 컴파일하고 실행하면 다음 이미지와 같이 데이터베이스의 데이터를 볼 수 있습니다.

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