Entity Framework - ฐานข้อมูลเมล็ดพันธุ์

ใน Entity Framework Seed ถูกนำมาใช้ใน EF 4.1 และทำงานร่วมกับตัวเริ่มต้นฐานข้อมูล แนวคิดทั่วไปของไฟล์Seed Methodคือการเริ่มต้นข้อมูลลงในฐานข้อมูลที่ Code First สร้างขึ้นหรือพัฒนาโดย Migrations ข้อมูลนี้มักเป็นข้อมูลการทดสอบ แต่อาจเป็นข้อมูลอ้างอิงเช่นรายชื่อนักเรียนที่รู้จักหลักสูตร ฯลฯ เมื่อข้อมูลเริ่มต้นข้อมูลจะดำเนินการดังต่อไปนี้ -

  • ตรวจสอบว่ามีฐานข้อมูลเป้าหมายอยู่แล้วหรือไม่
  • หากเป็นเช่นนั้นโมเดล Code First ปัจจุบันจะถูกเปรียบเทียบกับโมเดลที่เก็บไว้ในข้อมูลเมตาในฐานข้อมูล
  • ฐานข้อมูลจะหลุดหากโมเดลปัจจุบันไม่ตรงกับโมเดลในฐานข้อมูล
  • ฐานข้อมูลจะถูกสร้างขึ้นหากถูกทิ้งหรือไม่มีอยู่ตั้งแต่แรก
  • หากฐานข้อมูลถูกสร้างขึ้นเมธอด initializer 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);
   }
}

ในรหัสด้านบนตารางนักเรียนจะเริ่มต้น คุณต้องตั้งค่าคลาส DB initializer นี้ในคลาสบริบทดังที่แสดงในโค้ดต่อไปนี้

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

ต่อไปนี้เป็นการใช้คลาส MyContext แบบสมบูรณ์ซึ่งมีคลาส DB initializer ด้วย

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

เมื่อตัวอย่างข้างต้นถูกรวบรวมและดำเนินการคุณจะเห็นข้อมูลในฐานข้อมูลดังที่แสดงในภาพต่อไปนี้

เราขอแนะนำให้คุณดำเนินการตามตัวอย่างข้างต้นในลักษณะทีละขั้นตอนเพื่อความเข้าใจที่ดีขึ้น