एंटिटी फ्रेमवर्क - बीज डेटाबेस
एंटिटी फ्रेमवर्क में, बीज को EF 4.1 में पेश किया गया था और डेटाबेस इनिशियलाइज़र के साथ काम करता है। सामान्य विचार aSeed Methodएक डेटाबेस में डेटा को इनिशियलाइज़ करना है जो Code First द्वारा बनाया जा रहा है या माइग्रेशन द्वारा विकसित किया गया है। यह डेटा अक्सर परीक्षण डेटा है, लेकिन संदर्भ डेटा भी हो सकता है जैसे कि ज्ञात छात्रों की सूची, पाठ्यक्रम, आदि। जब डेटा को आरम्भ किया जाता है, तो यह निम्न कार्य करता है -
- जाँचता है कि लक्ष्य डेटाबेस पहले से मौजूद है या नहीं।
- यदि ऐसा होता है, तो वर्तमान कोड प्रथम मॉडल की तुलना डेटाबेस में मेटाडेटा में संग्रहीत मॉडल से की जाती है।
- यदि वर्तमान मॉडल डेटाबेस में मॉडल से मेल नहीं खाता है तो डेटाबेस को हटा दिया जाता है।
- डेटाबेस बनाया जाता है अगर यह गिरा दिया गया था या पहले स्थान पर मौजूद नहीं था।
- यदि डेटाबेस बनाया गया था, तो आरंभीकृत बीज विधि कहा जाता है।
बीज विधि डेटाबेस संदर्भ ऑब्जेक्ट को इनपुट पैरामीटर के रूप में लेती है, और विधि में कोड उस ऑब्जेक्ट का उपयोग डेटाबेस में नई संस्थाओं को जोड़ने के लिए करता है। अपने डेटाबेस में डेटा को सीड करने के लिए, आपको सीड विधि को ओवरराइड करने की आवश्यकता है। आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें कुछ डिफ़ॉल्ट डेटा को आंतरिक कक्षा में डेटाबेस में शुरू किया जाता है।
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);
}
}
}
जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है, तो आप डेटा को डेटाबेस में निम्न छवि में दिखाए अनुसार देख सकते हैं।
हम अनुशंसा करते हैं कि आप उपरोक्त उदाहरण को बेहतर समझ के लिए चरण-दर-चरण तरीके से निष्पादित करें।