Entity-framework-seed-database

提供:Dev Guides
移動先:案内検索

Entity Framework-シードデータベース

Entity Frameworkでは、シードはEF 4.1で導入され、データベース初期化子で機能します。 *シードメソッド*の一般的な考え方は、Code Firstによって作成されたデータベースまたはMigrationsによって進化したデータベースにデータを初期化することです。 このデータは多くの場合テストデータですが、既知の学生、コースなどのリストなどの参照データでもあります。 データが初期化されると、次のようになります-

  • ターゲットデータベースが既に存在するかどうかを確認します。
  • 存在する場合、現在の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);
      }
   }
}

上記の例をコンパイルして実行すると、次の図に示すように、データベース内のデータを確認できます。

データベース内のデータ

理解を深めるために、上記の例を段階的に実行することをお勧めします。