एंटिटी फ्रेमवर्क - कोड फर्स्ट माइग्रेशन
एंटिटी फ्रेमवर्क 4.3 में एक नया कोड फर्स्ट माइग्रेशन फ़ीचर शामिल है जो आपको डेटाबेस स्कीमा को समय-समय पर आपके मॉडल में बदलाव के रूप में विकसित करने की अनुमति देता है। अधिकांश डेवलपर्स के लिए, यह 4.1 और 4.2 रिलीज़ से डेटाबेस इनिशियलाइज़र विकल्पों पर एक बड़ा सुधार है जो आपको डेटाबेस को मैन्युअल रूप से अपडेट या ड्रॉप करने और इसे फिर से बनाने की आवश्यकता होती है जब आपका मॉडल बदल जाता है।
एंटिटी फ्रेमवर्क 4.3 से पहले, यदि आपके पास पहले से डेटा (बीज डेटा के अलावा) या आपके डेटाबेस में मौजूदा संग्रहीत कार्यविधियाँ, ट्रिगर आदि हैं, तो ये रणनीतियाँ पूरे डेटाबेस को छोड़ने और इसे फिर से बनाने के लिए उपयोग की जाती हैं, इसलिए आप डेटा और अन्य DB खो देंगे वस्तुओं।
माइग्रेशन के साथ, यह स्वचालित रूप से डेटाबेस स्कीमा को अपडेट करेगा, जब आपका मॉडल किसी भी मौजूदा डेटा या अन्य डेटाबेस ऑब्जेक्ट को खोए बिना बदल जाता है।
यह एक नया डेटाबेस इनिशियलाइज़र का उपयोग करता है जिसे MigrateDatabaseToLatestVersion कहा जाता है।
प्रवासन दो प्रकार के होते हैं -
- स्वचालित प्रवासन
- कोड आधारित प्रवासन
स्वचालित प्रवासन
ऑटोमेटेड माइग्रेशन को सबसे पहले एंटिटी फ्रेमवर्क 4.3 में पेश किया गया था। स्वचालित माइग्रेशन में आपको कोड फ़ाइल में मैन्युअल रूप से डेटाबेस माइग्रेशन को संसाधित करने की आवश्यकता नहीं होती है। उदाहरण के लिए, प्रत्येक परिवर्तन के लिए आपको अपने डोमेन वर्गों में भी बदलाव करना होगा। लेकिन स्वचालित माइग्रेशन के साथ आपको इसे पूरा करने के लिए पैकेज मैनेजर कंसोल में एक कमांड चलाना होगा।
आइए स्वचालित माइग्रेशन की निम्न चरण-दर-चरण प्रक्रिया पर एक नज़र डालें।
जब आप कोड प्रथम दृष्टिकोण का उपयोग करते हैं, तो आपके पास आवेदन के लिए डेटाबेस नहीं होता है।
इस उदाहरण में हम अपने 3 बुनियादी वर्गों जैसे कि छात्र, पाठ्यक्रम और नामांकन के साथ शुरू करेंगे, जैसा कि निम्नलिखित कोड में दिखाया गया है।
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; }
}
निम्नलिखित संदर्भ वर्ग है।
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; }
}
एप्लिकेशन को चलाने से पहले, आपको स्वचालित माइग्रेशन को सक्षम करना होगा।
Step 1 - टूल्स → नूगेट पैकेज मंगर → पैकेज मंगर कंसोल से ओपन पैकेज मैंगर कंसोल।
Step 2 - स्वचालित माइग्रेशन को सक्षम करने के लिए पैकेज मैनेजर कंसोल में निम्न कमांड चलाएं।
PM> enable-migrations -EnableAutomaticMigrations:$true
Step 3 - एक बार कमांड सफलतापूर्वक चलने के बाद, यह आपकी परियोजना के माइग्रेशन फ़ोल्डर में एक आंतरिक मोहरबंद विन्यास वर्ग बनाता है जैसा कि निम्नलिखित कोड में दिखाया गया है।
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 - नई डीबी आरंभीकरण रणनीति के साथ संदर्भ वर्ग में डेटाबेस इनिशियलाइज़र सेट करें 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- आपने स्वचालित माइग्रेशन सेट किया है। जब आप अपने एप्लिकेशन को निष्पादित करते हैं, तो यह स्वचालित रूप से माइग्रेशन को ध्यान में रखेगा, जब आप मॉडल को बदलते हैं।
Step 6- जैसा कि आप देख सकते हैं कि आपके डेटाबेस में अन्य टेबल के साथ एक सिस्टम टेबल __MigrationHistory भी बनाया गया है। __MigrationHistory में, स्वचालित माइग्रेशन डेटाबेस परिवर्तनों के इतिहास को बनाए रखता है।
Step 7- जब आप अपने डोमेन वर्ग के रूप में एक और इकाई वर्ग जोड़ते हैं और अपने आवेदन को निष्पादित करते हैं, तो यह आपके डेटाबेस में तालिका बनाएगा। चलिए निम्नलिखित StudentLogIn क्लास को जोड़ते हैं।
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 - उपरोक्त कोड के लिए DBSet को अपने संदर्भ वर्ग में जोड़ना न भूलें जैसा कि निम्नलिखित कोड में दिखाया गया है।
public virtual DbSet<StudentLogIn> StudentsLogIn { get; set; }
Step 9 - अपना एप्लिकेशन फिर से चलाएँ और आप देखेंगे कि StudentsLogIn टेबल आपके डेटाबेस में जुड़ गया है।
स्वचालित माइग्रेशन के लिए उल्लिखित उपरोक्त चरण केवल आपकी इकाई के लिए काम करेंगे। उदाहरण के लिए, किसी अन्य इकाई वर्ग को जोड़ने या मौजूदा निकाय वर्ग को निकालने के लिए यह सफलतापूर्वक माइग्रेट करेगा। लेकिन अगर आप अपने इकाई वर्ग में कोई संपत्ति जोड़ते या निकालते हैं तो यह एक अपवाद होगा।
Step 10 - संपत्ति माइग्रेशन को संभालने के लिए आपको विन्यास वर्ग निर्माता में AutomaticMigrationDataLossAllowed = true सेट करना होगा।
public Configuration() {
AutomaticMigrationsEnabled = true;
AutomaticMigrationDataLossAllowed = true;
ContextKey = "EFCodeFirstDemo.MyContext";
}
कोड आधारित प्रवासन
जब आप एक नया एप्लिकेशन विकसित करते हैं, तो आपका डेटा मॉडल बार-बार बदलता है, और हर बार जब मॉडल बदलता है, तो यह डेटाबेस के साथ सिंक से बाहर हो जाता है। आपने डेटा मॉडल को हर बार डेटाबेस को स्वचालित रूप से छोड़ने और बनाने के लिए एंटिटी फ्रेमवर्क को कॉन्फ़िगर किया है। जब आप माइग्रेशन पर अधिक नियंत्रण चाहते हैं तो कोड-आधारित माइग्रेशन उपयोगी होता है।
जब आप एंटिटी क्लासेस को जोड़ते, हटाते या बदलते हैं या अपना DbContext क्लास बदलते हैं, तो अगली बार जब आप एप्लिकेशन को चलाते हैं तो यह आपके मौजूदा डेटाबेस को स्वचालित रूप से हटा देता है, मॉडल से मेल खाने वाला एक नया बनाता है, और इसे टेस्ट डेटा के साथ बीज देता है।
कोड फ़र्स्ट माइग्रेशन फ़ीचर इस समस्या को हल करता है, कोड फ़ॉरमैट को अपडेट करने और डेटाबेस को फिर से बनाने के बजाय डेटाबेस स्कीमा को अपडेट करने में सक्षम बनाता है। एप्लिकेशन को परिनियोजित करने के लिए, आपको माइग्रेशन सक्षम करना होगा।
यहाँ डेटाबेस में परिवर्तन को स्थानांतरित करने का मूल नियम है -
- माइग्रेशन सक्षम करें
- माइग्रेशन जोड़ें
- डेटाबेस अद्यतन करें
आइए कोड-बेस प्रवासन की निम्नलिखित चरण-दर-चरण प्रक्रिया पर एक नज़र डालें।
जब आप कोड पहले दृष्टिकोण का उपयोग करते हैं, तो आपके पास आवेदन के लिए डेटाबेस नहीं होता है।
इस उदाहरण में हम फिर से अपने 3 बुनियादी वर्गों जैसे कि छात्र, पाठ्यक्रम और नामांकन के साथ शुरू करेंगे जैसा कि निम्नलिखित कोड में दिखाया गया है।
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; }
}
निम्नलिखित संदर्भ वर्ग है।
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 - एप्लिकेशन को चलाने से पहले आपको माइग्रेशन सक्षम करना होगा।
Step 2 - टूल्स से पैकेज मैनेजर कंसोल खोलें → नुगेट पैकेज मंगर → पैकेज मंगर कंसोल।
Step 3 - माइग्रेशन पहले से ही सक्षम है, अब अपने एप्लिकेशन में निम्न कमांड को निष्पादित करके माइग्रेशन जोड़ें।
PM> add-migration "UniDB Schema"
Step 4 - जब कमांड को सफलतापूर्वक निष्पादित किया जाता है, तो आप देखेंगे कि माइग्रेशन फ़ोल्डर में एक नई फाइल बनाई गई है, जिसे आप उस टाइमस्टैम्प उपसर्ग के साथ कमांड में पारित कर सकते हैं, जिसका नाम निम्न चित्र में दिखाया गया है।
Step 5 - आप "अपडेट-डेटाबेस" कमांड का उपयोग करके डेटाबेस बना या अपडेट कर सकते हैं।
PM> Update-Database -Verbose
"-Verbose" ध्वज कंसोल में लक्ष्य डेटाबेस पर लागू किए जा रहे SQL कथन को दिखाने के लिए निर्दिष्ट करता है।
Step 6 - चलो छात्र वर्ग में एक और संपत्ति 'आयु' जोड़ते हैं और फिर अपडेट स्टेटमेंट निष्पादित करते हैं।
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; }
}
जब आप PM → Update-Database -Verbose को निष्पादित करते हैं, जब कमांड को सफलतापूर्वक निष्पादित किया जाता है, तो आप देखेंगे कि आपके डेटाबेस में नया कॉलम एज जोड़ा गया है।
हम अनुशंसा करते हैं कि आप बेहतर समझ के लिए चरण-दर-चरण तरीके से उपरोक्त उदाहरण को निष्पादित करें।