एंटिटी फ्रेमवर्क - ट्रैक परिवर्तन

एंटिटी फ्रेमवर्क संस्थाओं और उनके संबंधों के लिए किए गए परिवर्तनों को ट्रैक करने की क्षमता प्रदान करता है, इसलिए डेटाबेस के संदर्भ में SaveChanges विधि कहा जाता है, तो सही अद्यतन किए जाते हैं। यह एंटिटी फ्रेमवर्क की एक प्रमुख विशेषता है।

  • परिवर्तन ट्रैकिंग ट्रैक इकाई संग्रह में नए रिकॉर्ड (ओं) को जोड़ते हुए परिवर्तन करता है, मौजूदा संस्थाओं को संशोधित या हटाता है।

  • फिर सभी परिवर्तन DbContext स्तर द्वारा रखे जाते हैं।

  • DbContext ऑब्जेक्ट के नष्ट होने से पहले सहेजे नहीं जाने पर ये ट्रैक परिवर्तन खो जाते हैं।

  • DbChangeTracker वर्ग आपको संदर्भ द्वारा ट्रैक की जा रही वर्तमान संस्थाओं के बारे में सभी जानकारी देता है।

  • किसी भी इकाई को संदर्भ द्वारा ट्रैक करने के लिए, उसके पास प्राथमिक कुंजी गुण होना चाहिए।

एंटिटी फ्रेमवर्क में, डिफ़ॉल्ट रूप से परिवर्तन ट्रैकिंग सक्षम है। आप DbContext की AutoDetectChangesEnabled संपत्ति को गलत पर सेट करके परिवर्तन ट्रैकिंग को अक्षम कर सकते हैं। यदि यह संपत्ति सही है, तो एंटिटी फ्रेमवर्क संस्थाओं की स्थिति को बनाए रखता है।

using (var context = new UniContextEntities()) {
   context.Configuration.AutoDetectChangesEnabled = true;
}

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें छात्रों और उनके नामांकन डेटाबेस से पुनर्प्राप्त किए जाते हैं।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Configuration.AutoDetectChangesEnabled = true;
         Console.WriteLine("Retrieve Student");

         var student = (from s in context.Students where s.FirstMidName == 
            "Ali" select s).FirstOrDefault<Student>();

         string name = student.FirstMidName + " " + student.LastName;
         Console.WriteLine("ID: {0}, Name: {1}", student.ID, name);
         Console.WriteLine();
         Console.WriteLine("Retrieve all related enrollments");

         foreach (var enrollment in student.Enrollments) {
            Console.WriteLine("Enrollment ID: {0}, Course ID: {1}", 
               enrollment.EnrollmentID, enrollment.CourseID);
         }

         Console.WriteLine();

         Console.WriteLine("Context tracking changes of {0} entity.", 
            context.ChangeTracker.Entries().Count());

         var entries = context.ChangeTracker.Entries();

         foreach (var entry in entries) {
            Console.WriteLine("Entity Name: {0}", entry.Entity.GetType().Name);
            Console.WriteLine("Status: {0}", entry.State);
         }

         Console.ReadKey();
      }
   }
}

जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है तो आपको निम्न आउटपुट प्राप्त होगा।

Retrieve Student 
ID: 1, Name: Ali Alexander
Retrieve all related enrollments
       Enrollment ID: 1, Course ID: 1050
       Enrollment ID: 2, Course ID: 4022
       Enrollment ID: 3, Course ID: 4041
Context tracking changes of 4 entity.
Entity Name: Student
Status: Unchanged
Entity Name: Enrollment
Status: Unchanged
Entity Name: Enrollment
Status: Unchanged
Entity Name: Enrollment
Status: Unchanged

आप देख सकते हैं कि सभी डेटा केवल डेटाबेस से पुनर्प्राप्त किए गए हैं, इसीलिए सभी संस्थाओं के लिए स्थिति अपरिवर्तित है।

आइए अब एक और सरल उदाहरण देखें, जिसमें हम एक और नामांकन जोड़ेंगे और एक छात्र को डेटाबेस से हटा देंगे। निम्नलिखित वह कोड है जिसमें नया नामांकन जोड़ा जाता है और एक छात्र को हटा दिया जाता है।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Configuration.AutoDetectChangesEnabled = true;

         Enrollment enr = new Enrollment() { 
            StudentID = 1, CourseID = 3141 
         };

         Console.WriteLine("Adding New Enrollment");
         context.Enrollments.Add(enr);
         Console.WriteLine("Delete Student");

         var student = (from s in context.Students where s.ID == 
            23 select s).SingleOrDefault<Student>();

         context.Students.Remove(student);
         Console.WriteLine("");

         Console.WriteLine("Context tracking changes of {0} entity.", 
            context.ChangeTracker.Entries().Count());
         var entries = context.ChangeTracker.Entries();

         foreach (var entry in entries) {
            Console.WriteLine("Entity Name: {0}", entry.Entity.GetType().Name);
            Console.WriteLine("Status: {0}", entry.State);
         }

         Console.ReadKey();
      }
   }
}

जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा।

Adding New Enrollment
Delete Student
Context tracking changes of 2 entity.
Entity Name: Enrollment
Status: Added
Entity Name: Student
Status: Deleted

अब आप देख सकते हैं कि नामांकन इकाई की स्थिति को जोड़ा गया है, और छात्र इकाई की स्थिति को हटा दिया गया है, क्योंकि नया नामांकन जोड़ा गया है और एक छात्र को डेटाबेस से हटा दिया गया है।

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