Kerangka Kerja Entitas - Beberapa DbContext
Dalam bab ini, kita akan mempelajari cara memigrasi perubahan ke dalam database saat ada beberapa kelas DbContext dalam aplikasi.
- Beberapa DbContext pertama kali diperkenalkan di Entity Framework 6.0.
- Beberapa kelas konteks mungkin termasuk dalam satu database atau dua database yang berbeda.
Dalam contoh kita, kita akan mendefinisikan dua kelas Konteks untuk database yang sama. Dalam kode berikut, ada dua kelas DbContext untuk Siswa dan Guru.
public class Student {
public int ID { get; set; }
public string LastName { get; set; }
public string FirstMidName { get; set; }
public DateTime EnrollmentDate { get; set; }
}
public class MyStudentContext : DbContext {
public MyStudentContext() : base("UniContextDB") {}
public virtual DbSet<Student> Students { get; set; }
}
public class Teacher {
public int ID { get; set; }
public string LastName { get; set; }
public string FirstMidName { get; set; }
public DateTime HireDate { get; set; }
}
public class MyTeacherContext : DbContext {
public MyTeacherContext() : base("UniContextDB") {}
public virtual DbSet<Teacher> Teachers { get; set; }
}
Seperti yang Anda lihat pada kode di atas, ada dua model yang disebut "Siswa" dan "Guru". Masing-masing dikaitkan dengan kelas konteks tertentu yang sesuai, yaitu, Siswa dikaitkan dengan MyStudentContext dan Guru dikaitkan dengan MyTeacherContext.
Berikut adalah aturan dasar untuk memigrasi perubahan dalam database, ketika ada beberapa kelas Konteks dalam proyek yang sama.
aktifkan-migrasi -ContextTypeName <DbContext-Name-with-Namespaces> MigrationsDirectory: <Migrations-Directory-Name>
Add-Migration -configuration <DbContext-Migrations-Configuration-Class-withNamespaces> <Migrations-Name>
Perbarui-Database -configuration <DbContext-Migrations-Configuration-Class-withNamespaces> -Verbose
Mari aktifkan migrasi untuk MyStudentContext dengan menjalankan perintah berikut di Package Manager Console.
PM→ enable-migrations -ContextTypeName:EFCodeFirstDemo.MyStudentContext
Setelah dijalankan, kami akan menambahkan model dalam riwayat migrasi dan untuk itu, kami harus mengaktifkan perintah add-migrasi di konsol yang sama.
PM→ add-migration -configuration EFCodeFirstDemo.Migrations.Configuration Initial
Sekarang mari kita tambahkan beberapa data ke dalam tabel Siswa dan Guru di database.
static void Main(string[] args) {
using (var context = new MyStudentContext()) {
//// Create and save a new Students
Console.WriteLine("Adding new students");
var student = new Student {
FirstMidName = "Alain",
LastName = "Bomer",
EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
//Age = 24
};
context.Students.Add(student);
var student1 = new Student {
FirstMidName = "Mark",
LastName = "Upston",
EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
//Age = 30
};
context.Students.Add(student1);
context.SaveChanges();
// Display all Students from the database
var students = (from s in context.Students orderby s.FirstMidName
select s).ToList<Student>();
Console.WriteLine("Retrieve all Students from the database:");
foreach (var stdnt in students) {
string name = stdnt.FirstMidName + " " + stdnt.LastName;
Console.WriteLine("ID: {0}, Name: {1}", stdnt.ID, name);
}
Console.WriteLine("Press any key to exit...");
Console.ReadKey();
}
using (var context = new MyTeacherContext()) {
//// Create and save a new Teachers
Console.WriteLine("Adding new teachers");
var student = new Teacher {
FirstMidName = "Alain",
LastName = "Bomer",
HireDate = DateTime.Parse(DateTime.Today.ToString())
//Age = 24
};
context.Teachers.Add(student);
var student1 = new Teacher {
FirstMidName = "Mark",
LastName = "Upston",
HireDate = DateTime.Parse(DateTime.Today.ToString())
//Age = 30
};
context.Teachers.Add(student1);
context.SaveChanges();
// Display all Teachers from the database
var teachers = (from t in context.Teachers orderby t.FirstMidName
select t).ToList<Teacher>();
Console.WriteLine("Retrieve all teachers from the database:");
foreach (var teacher in teachers) {
string name = teacher.FirstMidName + " " + teacher.LastName;
Console.WriteLine("ID: {0}, Name: {1}", teacher.ID, name);
}
Console.WriteLine("Press any key to exit...");
Console.ReadKey();
}
}
Ketika kode di atas dijalankan, Anda akan melihat bahwa dua tabel berbeda dibuat untuk dua model berbeda seperti yang ditunjukkan pada gambar berikut.
Kami menyarankan Anda untuk menjalankan contoh di atas dengan cara langkah demi langkah untuk pemahaman yang lebih baik.