Kerangka Kerja Entitas - Migrasi Pertama Kode

Entity Framework 4.3 menyertakan fitur Migrasi Pertama Kode baru yang memungkinkan Anda untuk secara bertahap mengembangkan skema database saat model Anda berubah seiring waktu. Untuk sebagian besar pengembang, ini merupakan peningkatan besar atas opsi penginisialisasi database dari rilis 4.1 dan 4.2 yang mengharuskan Anda memperbarui database secara manual atau melepaskan dan membuatnya kembali saat model Anda berubah.

  • Sebelum Entity Framework 4.3, jika Anda sudah memiliki data (selain data seed) atau Stored Procedures, trigger, dll. Yang ada di database Anda, strategi ini digunakan untuk membuang seluruh database dan membuatnya kembali, sehingga Anda akan kehilangan data dan DB lainnya. benda.

  • Dengan migrasi, itu akan secara otomatis memperbarui skema database, ketika model Anda berubah tanpa kehilangan data yang ada atau objek database lainnya.

  • Ini menggunakan penginisialisasi database baru yang disebut MigrateDatabaseToLatestVersion.

Ada dua jenis Migrasi -

  • Migrasi Otomatis
  • Migrasi berbasis kode

Migrasi Otomatis

Migrasi Otomatis pertama kali diperkenalkan dalam kerangka Entitas 4.3. Dalam migrasi otomatis, Anda tidak perlu memproses migrasi database secara manual dalam file kode. Misalnya, untuk setiap perubahan, Anda juga perlu mengubah kelas domain Anda. Tetapi dengan migrasi otomatis Anda hanya perlu menjalankan perintah di Package Manager Console untuk menyelesaikannya.

Mari kita lihat proses langkah demi langkah migrasi otomatis berikut.

Saat Anda menggunakan pendekatan Code First, Anda tidak memiliki database untuk aplikasi Anda.

Dalam contoh ini kita akan memulai dengan 3 kelas dasar kita seperti Siswa, Kursus dan Pendaftaran seperti yang ditunjukkan pada kode berikut.

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }

}

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   [Index]
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

Berikut adalah kelas konteks.

public class MyContext : DbContext {
   public MyContext() : base("MyContextDB") {}
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

Sebelum menjalankan aplikasi, Anda perlu mengaktifkan migrasi otomatis.

Step 1 - Buka Package Manger Console dari Tools → NuGet Package Manger → Package Manger Console.

Step 2 - Untuk mengaktifkan migrasi otomatis, jalankan perintah berikut di Package Manager Console.

PM> enable-migrations -EnableAutomaticMigrations:$true

Step 3 - Setelah perintah berhasil dijalankan, itu membuat kelas Konfigurasi tertutup internal di folder Migrasi proyek Anda seperti yang ditunjukkan pada kode berikut.

namespace EFCodeFirstDemo.Migrations {

   using System;
   using System.Data.Entity;
   using System.Data.Entity.Migrations;
   using System.Linq;
	
   internal sealed class Configuration : DbMigrationsConfiguration<EFCodeFirstDemo.MyContext> {

      public Configuration() {
         AutomaticMigrationsEnabled = true;
         ContextKey = "EFCodeFirstDemo.MyContext";
      }

      protected override void Seed(EFCodeFirstDemo.MyContext context) {

         //  This method will be called after migrating to the latest version.
         //  You can use the DbSet<T>.AddOrUpdate() helper extension method
         //  to avoid creating duplicate seed data. E.g.

         //  context.People.AddOrUpdate(
            //  p ⇒ p.FullName, 
            //  new Person { FullName = "Andrew Peters" }, 
            //  new Person { FullName = "Brice Lambson" }, 
            //  new Person { FullName = "Rowan Miller" }
         //  );
      }
   }
}

Step 4 - Tetapkan penginisialisasi database di kelas konteks dengan strategi inisialisasi DB baru MigrateDatabaseToLatestVersion.

public class MyContext : DbContext {

   public MyContext() : base("MyContextDB") {
      Database.SetInitializer(new MigrateDatabaseToLatestVersion<MyContext, 
         EFCodeFirstDemo.Migrations.Configuration>("MyContextDB"));
   }

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }

}

Step 5- Anda telah menyiapkan migrasi otomatis. Saat Anda menjalankan aplikasi Anda, maka secara otomatis akan menangani migrasi, saat Anda mengubah model.

Step 6- Seperti yang Anda lihat, satu tabel sistem __MigrationHistory juga dibuat di database Anda dengan tabel lain. Di __MigrationHistory, migrasi otomatis menyimpan riwayat perubahan basis data.

Step 7- Ketika Anda menambahkan kelas entitas lain sebagai kelas domain Anda dan menjalankan aplikasi Anda, maka itu akan membuat tabel di database Anda. Mari tambahkan kelas StudentLogIn berikut.

public class StudentLogIn {
   [Key, ForeignKey("Student")]
   public int ID { get; set; }
   public string EmailID { get; set; }
   public string Password { get; set; }
	
   public virtual Student Student { get; set; }
}

Step 8 - Jangan lupa menambahkan DBSet untuk kelas yang disebutkan di atas dalam kelas konteks Anda seperti yang ditunjukkan pada kode berikut.

public virtual DbSet<StudentLogIn> StudentsLogIn { get; set; }

Step 9 - Jalankan aplikasi Anda lagi dan Anda akan melihat bahwa tabel StudentsLogIn ditambahkan ke database Anda.

Langkah-langkah di atas yang disebutkan untuk migrasi otomatis hanya akan berfungsi untuk entitas Anda. Misalnya, untuk menambahkan kelas entitas lain atau menghapus kelas entitas yang ada itu akan berhasil dimigrasi. Tetapi jika Anda menambahkan atau menghapus properti apa pun ke kelas entitas Anda, maka itu akan memunculkan pengecualian.

Step 10 - Untuk menangani migrasi properti Anda perlu menyetel AutomaticMigrationDataLossAllowed = true dalam konstruktor kelas konfigurasi.

public Configuration() {
   AutomaticMigrationsEnabled = true;
   AutomaticMigrationDataLossAllowed = true;
   ContextKey = "EFCodeFirstDemo.MyContext";
}

Migrasi Berbasis Kode

Saat Anda mengembangkan aplikasi baru, model data Anda sering berubah, dan setiap kali model berubah, model tersebut tidak sinkron dengan database. Anda telah mengonfigurasi Entity Framework untuk secara otomatis menjatuhkan dan membuat ulang database setiap kali Anda mengubah model data. Migrasi berbasis kode berguna ketika Anda menginginkan kontrol lebih pada migrasi.

  • Saat Anda menambahkan, menghapus, atau mengubah kelas entitas atau mengubah kelas DbContext Anda, saat berikutnya Anda menjalankan aplikasi, secara otomatis menghapus database yang sudah ada, membuat database baru yang cocok dengan model, dan menyemainya dengan data pengujian.

  • Fitur Code First Migrations memecahkan masalah ini dengan mengaktifkan Code First untuk memperbarui skema database, bukan menghapus dan membuat ulang database. Untuk menerapkan aplikasi, Anda harus mengaktifkan Migrasi.

Berikut adalah aturan dasar untuk memigrasi perubahan dalam database -

  • Aktifkan Migrasi
  • Tambahkan Migrasi
  • Perbarui Database

Mari kita lihat proses langkah demi langkah migrasi basis kode berikut.

Saat Anda menggunakan pendekatan pertama kode, Anda tidak memiliki database untuk aplikasi Anda.

Dalam contoh ini kita akan memulai lagi dengan 3 kelas dasar kita seperti Pelajar, Kursus dan Pendaftaran seperti yang ditunjukkan pada kode berikut.

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }

}

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   [Index]
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

Berikut adalah kelas konteks.

public class MyContext : DbContext {

   public MyContext() : base("MyContextDB") {
      Database.SetInitializer(new MigrateDatabaseToLatestVersion<
         MyContext, EFCodeFirstDemo.Migrations.Configuration>("MyContextDB"));
   }

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }

}

Step 1 - Sebelum menjalankan aplikasi, Anda perlu mengaktifkan migrasi.

Step 2 - Buka Konsol Pengelola Paket dari Tools → NuGet Package Manger → Package Manger Console.

Step 3 - Migrasi sudah diaktifkan, sekarang tambahkan migrasi di aplikasi Anda dengan menjalankan perintah berikut.

PM> add-migration "UniDB Schema"

Step 4 - Ketika perintah berhasil dijalankan maka Anda akan melihat file baru telah dibuat di folder Migrasi dengan nama parameter yang Anda berikan ke perintah dengan awalan stempel waktu seperti yang ditunjukkan pada gambar berikut.

Step 5 - Anda dapat membuat atau memperbarui database menggunakan perintah "update-database".

PM> Update-Database -Verbose

Bendera "-Verbose" menentukan untuk menampilkan Pernyataan SQL yang diterapkan ke database target di konsol.

Step 6 - Mari tambahkan satu properti lagi 'Usia' di kelas siswa lalu jalankan pernyataan pembaruan.

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public int Age { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

Ketika Anda menjalankan PM → Update-Database –Verbose, ketika perintah berhasil dijalankan Anda akan melihat kolom baru Age ditambahkan ke database Anda.

Kami menyarankan Anda untuk menjalankan contoh di atas dengan cara langkah demi langkah untuk pemahaman yang lebih baik.