इकाई ढाँचा - एकाधिक DbContext

इस अध्याय में, हम सीखेंगे कि डेटाबेस में परिवर्तन कैसे करें जब अनुप्रयोग में कई DbContext कक्षाएं हैं।

  • मल्टीपल DbContext को पहली बार Entity Framework 6.0 में पेश किया गया था।
  • एकाधिक संदर्भ कक्षाएं एक एकल डेटाबेस या दो अलग-अलग डेटाबेस से संबंधित हो सकती हैं।

हमारे उदाहरण में, हम एक ही डेटाबेस के लिए दो संदर्भ वर्गों को परिभाषित करेंगे। निम्नलिखित कोड में, छात्र और शिक्षक के लिए दो DbContext कक्षाएं हैं।

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; }
}

जैसा कि आप उपरोक्त कोड में देख सकते हैं, "मॉडल" और "शिक्षक" नामक दो मॉडल हैं। प्रत्येक एक विशेष संबंधित संदर्भ वर्ग के साथ जुड़ा हुआ है, अर्थात, छात्र MyStudentContext के साथ जुड़ा हुआ है और शिक्षक MyTeacherContext के साथ जुड़ा हुआ है।

यहां डेटाबेस में परिवर्तन को स्थानांतरित करने का मूल नियम है, जब एक ही परियोजना के भीतर कई संदर्भ कक्षाएं हैं।

  • सक्षम-माइग्रेशन -ContextTypeName <DbContext-Name-with-Namespaces> MigrationsDirectory: <माइग्रेशन-निर्देशिका-नाम>

  • ऐड-माइग्रेशन -configuration <DbContext-Migrations-configuration-Class-withNamespaces> <माइग्रेशन-नाम>

  • अपडेट-डेटाबेस -configuration <DbContext-Migrations-कॉन्फ़िगरेशन-क्लास-with -Namespaces> -Verbose

पैकेज प्रबंधक कंसोल में निम्न कमांड निष्पादित करके MyStudentContext के लिए माइग्रेशन सक्षम करें।

PM→ enable-migrations -ContextTypeName:EFCodeFirstDemo.MyStudentContext

एक बार जब यह निष्पादित हो जाता है, तो हम मॉडल को माइग्रेशन इतिहास में जोड़ देंगे और उसके लिए, हमें उसी कंसोल में ऐड-माइग्रेशन कमांड को फायर करना होगा।

PM→ add-migration -configuration EFCodeFirstDemo.Migrations.Configuration Initial

आइए अब डेटाबेस में छात्रों और शिक्षकों की तालिकाओं में कुछ डेटा जोड़ते हैं।

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();
   }
}

जब उपरोक्त कोड निष्पादित किया जाता है, तो आप देखेंगे कि दो अलग-अलग मॉडल के लिए दो अलग-अलग तालिकाएँ बनाई गई हैं जैसा कि निम्नलिखित छवि में दिखाया गया है।

हम अनुशंसा करते हैं कि आप बेहतर समझ के लिए चरण-दर-चरण तरीके से उपरोक्त उदाहरण को निष्पादित करें।