实体框架 - 种子数据库



在实体框架中,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

我们建议您逐步执行上述示例,以便更好地理解。

广告