एंटिटी फ्रेमवर्क - डिस्कनेक्टेड एंटिटीज

इस अध्याय में, आइए देखें कि कैसे उन संस्थाओं में बदलाव किया जा सकता है जिन्हें किसी संदर्भ द्वारा ट्रैक नहीं किया जा रहा है। जिन संदर्भों को एक संदर्भ द्वारा ट्रैक नहीं किया जा रहा है, उन्हें 'डिस्कनेक्टेड' संस्थाओं के रूप में जाना जाता है।

  • अधिकांश एकल-स्तरीय अनुप्रयोगों के लिए, जहाँ उपयोगकर्ता इंटरफ़ेस और डेटाबेस एक्सेस लेयर्स एक ही आवेदन प्रक्रिया में चलते हैं, आप संभवतः केवल उन संस्थाओं पर कार्य कर रहे होंगे जिन्हें किसी संदर्भ द्वारा ट्रैक किया जा रहा है।

  • एन-टियर अनुप्रयोगों में डिस्कनेक्टेड संस्थाओं पर संचालन अधिक सामान्य है।

  • एन-टियर एप्लिकेशन में एक सर्वर पर कुछ डेटा प्राप्त करना और इसे नेटवर्क पर, क्लाइंट मशीन पर वापस करना शामिल है।

  • क्लाइंट एप्लिकेशन को सर्वर पर बने रहने के लिए उसे वापस करने से पहले इस डेटा में हेरफेर करता है।

निम्नलिखित दो चरण हैं जिन्हें डिस्कनेक्ट किए गए इकाई ग्राफ या यहां तक ​​कि एकल डिस्कनेक्ट किए गए इकाई के साथ लेने की आवश्यकता है।

  • नए संदर्भ उदाहरण के साथ संस्थाओं को संलग्न करें और इन संस्थाओं के बारे में संदर्भ को जागरूक करें।

  • मैन्युअल रूप से इन संस्थाओं के लिए उपयुक्त EntityStates सेट करें।

आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें छात्र इकाई को दो नामांकन संस्थाओं के साथ जोड़ा गया है।

class Program {

   static void Main(string[] args) {

      var student = new Student {

         ID = 1001,
         FirstMidName = "Wasim",
         LastName = "Akram", 

         EnrollmentDate = DateTime.Parse("2015-10-10"), 
            Enrollments = new List<Enrollment> {

               new Enrollment{EnrollmentID = 2001,CourseID = 4022, StudentID = 1001 },
               new Enrollment{EnrollmentID = 2002,CourseID = 4025, StudentID = 1001 },
         }
      };

      using (var context = new UniContextEntities()) {

         context.Students.Add(student);
         Console.WriteLine("New Student ({0} {1}): {2}", 
            student.FirstMidName, student.LastName, context.Entry(student).State);

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

         Console.WriteLine("Press any key to exit...");
         Console.ReadKey();
      }
   } 
}
  • कोड एक नया छात्र उदाहरण बनाता है, जो अपनी नामांकन संपत्ति में दो नए नामांकन उदाहरणों का संदर्भ देता है।

  • फिर Add Method का उपयोग करके नए छात्र को एक संदर्भ में जोड़ा जाता है।

  • छात्र के जुड़ जाने के बाद, कोड उस ट्रैकिंग सूचना का उपयोग करने के लिए DbContext.Entry विधि का उपयोग करता है, जो Entity Framework में नए छात्र के बारे में है।

  • इस परिवर्तन ट्रैकिंग सूचना से, राज्य की संपत्ति का उपयोग इकाई की वर्तमान स्थिति को लिखने के लिए किया जाता है।

  • यह प्रक्रिया तब नए बनाए गए प्रत्येक नामांकन के लिए दोहराई जाती है जिसे नए छात्र से संदर्भित किया जाता है। यदि आप एप्लिकेशन चलाते हैं, तो आपको निम्न आउटपुट प्राप्त होंगे -

New Student   (Wasim  Akram): Added
Enrollment ID: 2001 State: Added
Enrollment ID: 2002 State: Added
Press any key to exit...

जबकि DbSet.Add का उपयोग एंटिटी फ्रेमवर्क को नई संस्थाओं के बारे में बताने के लिए किया जाता है, DbSet.Attach का उपयोग एंटिटी फ्रेमवर्क को मौजूदा संस्थाओं के बारे में बताने के लिए किया जाता है। अटैच विधि अपरिवर्तित स्थिति में एक इकाई को चिह्नित करेगी।

आइए निम्नलिखित सी # कोड पर एक नज़र डालें जिसमें एक डिस्कनेक्ट की गई इकाई DbContext के साथ जुड़ी हुई है।

class Program {

   static void Main(string[] args) {

      var student = new Student {

         ID = 1001,
         FirstMidName = "Wasim",
         LastName = "Akram",
         EnrollmentDate = DateTime.Parse("2015-10-10"), 

         Enrollments = new List<Enrollment> {
            new Enrollment { EnrollmentID = 2001, CourseID = 4022, StudentID = 1001 },
            new Enrollment { EnrollmentID = 2002, CourseID = 4025, StudentID = 1001 },
         }
			
      };

      using (var context = new UniContextEntities()) {

         context.Students.Attach(student);
         Console.WriteLine("New Student ({0} {1}): {2}", 
            student.FirstMidName, student.LastName, context.Entry(student).State);

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

         Console.WriteLine("Press any key to exit...");
         Console.ReadKey();
      }
   }
}

जब उपरोक्त कोड अटैच () विधि से निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा।

New Student   (Wasim  Akram): Unchanged
Enrollment ID: 2001 State: Unchanged
Enrollment ID: 2002 State: Unchanged
Press any key to exit...