इकाई ढांचा - आलसी लोड हो रहा है
आलसी लोडिंग एक ऐसी प्रक्रिया है जिसके तहत किसी संस्था या संस्थाओं के संग्रह को स्वचालित रूप से पहली बार डेटाबेस से लोड किया जाता है, जो कि इकाई / संस्थाओं का जिक्र करने वाली संपत्ति तक पहुँचा जाता है। आलसी लोडिंग का मतलब संबंधित डेटा को लोड करने में देरी करना है, जब तक कि आप इसके लिए विशेष रूप से अनुरोध नहीं करते हैं।
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
हम आपको बेहतर समझ के लिए चरण-दर-चरण तरीके से उपरोक्त उदाहरण को निष्पादित करने की सलाह देते हैं।