Entity Framework-다중 DbContext

이 장에서는 애플리케이션에 여러 DbContext 클래스가있을 때 변경 사항을 데이터베이스로 마이그레이션하는 방법을 학습합니다.

  • 다중 DbContext는 Entity Framework 6.0에서 처음 도입되었습니다.
  • 여러 컨텍스트 클래스는 단일 데이터베이스 또는 두 개의 서로 다른 데이터베이스에 속할 수 있습니다.

이 예에서는 동일한 데이터베이스에 대해 두 개의 Context 클래스를 정의합니다. 다음 코드에는 Student 및 Teacher에 대한 두 개의 DbContext 클래스가 있습니다.

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
}

public class MyStudentContext : DbContext {
   public MyStudentContext() : base("UniContextDB") {}
   public virtual DbSet<Student> Students { get; set; }
}

public class Teacher {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime HireDate { get; set; }
}

public class MyTeacherContext : DbContext {
   public MyTeacherContext() : base("UniContextDB") {}
   public virtual DbSet<Teacher> Teachers { get; set; }
}

위 코드에서 볼 수 있듯이“Student”와“Teacher”라는 두 가지 모델이 있습니다. 각각은 특정 해당 컨텍스트 클래스와 연관됩니다. 즉, Student는 MyStudentContext와 연관되고 Teacher는 MyTeacherContext와 연관됩니다.

다음은 동일한 프로젝트 내에 여러 컨텍스트 클래스가있는 경우 데이터베이스의 변경 사항을 마이그레이션하는 기본 규칙입니다.

  • enable-migrations -ContextTypeName <DbContext-Name-with-Namespaces> MigrationsDirectory : <Migrations-Directory-Name>

  • Add-Migration -configuration <DbContext-Migrations-Configuration-Class-withNamespaces> <Migrations-Name>

  • Update-Database -configuration <DbContext-Migrations-Configuration-Class-withNamespaces> -Verbose

패키지 관리자 콘솔에서 다음 명령을 실행하여 MyStudentContext에 대한 마이그레이션을 활성화하겠습니다.

PM→ enable-migrations -ContextTypeName:EFCodeFirstDemo.MyStudentContext

일단 실행되면 마이그레이션 내역에 모델을 추가하고이를 위해 동일한 콘솔에서 add-migration 명령을 실행해야합니다.

PM→ add-migration -configuration EFCodeFirstDemo.Migrations.Configuration Initial

이제 데이터베이스의 Students 및 Teachers 테이블에 데이터를 추가해 보겠습니다.

static void Main(string[] args) {

   using (var context = new MyStudentContext()) {
	
      //// Create and save a new Students
      Console.WriteLine("Adding new students");

      var student = new Student {
         FirstMidName = "Alain", 
         LastName = "Bomer", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 24
      };

      context.Students.Add(student);

      var student1 = new Student {
         FirstMidName = "Mark",
         LastName = "Upston", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 30
      };

      context.Students.Add(student1);
      context.SaveChanges();
		
      // Display all Students from the database
      var students = (from s in context.Students orderby s.FirstMidName
         select s).ToList<Student>();
		
      Console.WriteLine("Retrieve all Students from the database:");

      foreach (var stdnt in students) {
         string name = stdnt.FirstMidName + " " + stdnt.LastName;
         Console.WriteLine("ID: {0}, Name: {1}", stdnt.ID, name);
      }

      Console.WriteLine("Press any key to exit...");
      Console.ReadKey();
   }

   using (var context = new MyTeacherContext()) {

      //// Create and save a new Teachers
      Console.WriteLine("Adding new teachers");

      var student = new Teacher {
         FirstMidName = "Alain", 
         LastName = "Bomer", 
         HireDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 24
      };

      context.Teachers.Add(student);

      var student1 = new Teacher {
         FirstMidName = "Mark", 
         LastName = "Upston", 
         HireDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 30
      };

      context.Teachers.Add(student1);
      context.SaveChanges();
  
      // Display all Teachers from the database
      var teachers = (from t in context.Teachers orderby t.FirstMidName
         select t).ToList<Teacher>();
		
      Console.WriteLine("Retrieve all teachers from the database:");

      foreach (var teacher in teachers) {
         string name = teacher.FirstMidName + " " + teacher.LastName;
         Console.WriteLine("ID: {0}, Name: {1}", teacher.ID, name);
      }

      Console.WriteLine("Press any key to exit...");
      Console.ReadKey();
   }
}

위의 코드가 실행되면 다음 이미지와 같이 두 개의 다른 모델에 대해 두 개의 다른 테이블이 생성되는 것을 볼 수 있습니다.

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