इकाई ढांचा - आलसी लोड हो रहा है

आलसी लोडिंग एक ऐसी प्रक्रिया है जिसके तहत किसी संस्था या संस्थाओं के संग्रह को स्वचालित रूप से पहली बार डेटाबेस से लोड किया जाता है, जो कि इकाई / संस्थाओं का जिक्र करने वाली संपत्ति तक पहुँचा जाता है। आलसी लोडिंग का मतलब संबंधित डेटा को लोड करने में देरी करना है, जब तक कि आप इसके लिए विशेष रूप से अनुरोध नहीं करते हैं।

  • POCO निकाय प्रकारों का उपयोग करते समय, आलसी लोडिंग को प्राप्त प्रॉक्सी प्रकारों के उदाहरण बनाकर प्राप्त किया जाता है और फिर लोडिंग हुक को जोड़ने के लिए आभासी गुणों को ओवरराइड किया जाता है।

  • आलसी लोडिंग बहुत डिफ़ॉल्ट है।

  • यदि आप डिफ़ॉल्ट कॉन्फ़िगरेशन को छोड़ देते हैं, और स्पष्ट रूप से अपनी क्वेरी में एंटिटी फ्रेमवर्क को नहीं बताते हैं कि आप आलसी लोडिंग के अलावा कुछ चाहते हैं, तो आलसी लोडिंग वही है जो आपको मिलेगा।

  • उदाहरण के लिए, छात्र इकाई वर्ग का उपयोग करते समय, संबंधित एनरोलमेंट पहली बार एनरोलमेंट नेविगेशन संपत्ति तक पहुंचने के बाद लोड किए जाएंगे।

  • नेविगेशन संपत्ति को सार्वजनिक, आभासी के रूप में परिभाषित किया जाना चाहिए। प्रसंग करेगाNOT यदि संपत्ति को आभासी के रूप में परिभाषित नहीं किया गया है तो आलसी लोडिंग करें।

निम्नलिखित एक छात्र वर्ग है जिसमें नामांकन की नेविगेशन संपत्ति है।

public partial class Student {

   public Student() {
      this.Enrollments = new HashSet<Enrollment>();
   }
	
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public System.DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

आइए एक सरल उदाहरण देखें जिसमें छात्र सूची को पहले डेटाबेस से लोड किया गया है और फिर यह किसी विशेष छात्र के नामांकन को लोड करेगा जब भी आपको इसकी आवश्यकता होती है।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         //Loading students only
         IList<Student> students = context.Students.ToList<Student>();

         foreach (var student in students) {

            string name = student.FirstMidName + " " + student.LastName;
            Console.WriteLine("ID: {0}, Name: {1}", student.ID, name);
	
            foreach (var enrollment in student.Enrollments) {
               Console.WriteLine("Enrollment ID: {0}, Course ID: {1}", 
                  enrollment.EnrollmentID, enrollment.CourseID);
            }
         }

         Console.ReadKey();
      }
   }
}

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

ID: 1, Name: Ali Alexander
       Enrollment ID: 1, Course ID: 1050
       Enrollment ID: 2, Course ID: 4022
       Enrollment ID: 3, Course ID: 4041
ID: 2, Name: Meredith Alonso
       Enrollment ID: 4, Course ID: 1045
       Enrollment ID: 5, Course ID: 3141
       Enrollment ID: 6, Course ID: 2021
ID: 3, Name: Arturo Anand
       Enrollment ID: 7, Course ID: 1050
ID: 4, Name: Gytis Barzdukas
       Enrollment ID: 8, Course ID: 1050
       Enrollment ID: 9, Course ID: 4022
ID: 5, Name: Yan Li
       Enrollment ID: 10, Course ID: 4041
ID: 6, Name: Peggy Justice
       Enrollment ID: 11, Course ID: 1045
ID: 7, Name: Laura Norman
       Enrollment ID: 12, Course ID: 3141

आलसी लोडिंग बंद करें

आलसी लोडिंग और क्रमांकन अच्छी तरह से मिश्रण नहीं करते हैं, और यदि आप सावधान नहीं हैं, तो आप अपने पूरे डेटाबेस के लिए क्वेरी को समाप्त कर सकते हैं, क्योंकि आलसी लोडिंग सक्षम है। किसी इकाई को अनुक्रमित करने से पहले आलसी लोडिंग को बंद करना एक अच्छा अभ्यास है।

विशिष्ट नेविगेशन गुणों के लिए बंद करना

नामांकन संग्रह के आलसी लोडिंग को नामांकन संपत्ति को गैर-आभासी बनाकर बंद किया जा सकता है जैसा कि निम्नलिखित उदाहरण में दिखाया गया है।

public partial class Student { 

   public Student() { 
      this.Enrollments = new HashSet<Enrollment>(); 
   }
	
   public int ID { get; set; } 
   public string LastName { get; set; } 
   public string FirstMidName { get; set; } 
   public System.DateTime EnrollmentDate { get; set; }
	
   public ICollection<Enrollment> Enrollments { get; set; } 
}

सभी संस्थाओं के लिए बंद

निम्न उदाहरण में दिखाए गए अनुसार झूठा कॉन्फ़िगरेशन के लिए झंडे को सेट करके संदर्भ में सभी संस्थाओं के लिए आलसी लोडिंग को बंद किया जा सकता है।

public partial class UniContextEntities : DbContext { 

   public UniContextEntities(): base("name = UniContextEntities") {
      this.Configuration.LazyLoadingEnabled = false;
   }
	
   protected override void OnModelCreating(DbModelBuilder modelBuilder) { 
      throw new UnintentionalCodeFirstException(); 
   } 
}

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

ID: 1, Name: Ali Alexander
ID: 2, Name: Meredith Alons
ID: 3, Name: Arturo Anand
ID: 4, Name: Gytis Barzduka
ID: 5, Name: Yan Li
ID: 6, Name: Peggy Justice
ID: 7, Name: Laura Norman
ID: 8, Name: Nino Olivetto

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