實體框架 - 種子資料庫



在實體框架中,Seed 在 EF 4.1 中引入,並與資料庫初始化器一起使用。Seed 方法 的基本思想是將資料初始化到由 Code 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>());
}

以下是 MyContext 類的完整類實現,其中還包含 DB 初始化器類。

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);
      }
   } 
}

編譯並執行上述示例後,您可以在資料庫中看到資料,如下面的影像所示。

Data In Database

我們建議您逐步執行上述示例,以便更好地理解。

廣告

© . All rights reserved.