एंटिटी फ्रेमवर्क - एगर लोडिंग

ईगर लोडिंग एक ऐसी प्रक्रिया है जिसके तहत एक प्रकार की इकाई के लिए एक क्वेरी भी संबंधित संस्थाओं को क्वेरी के हिस्से के रूप में लोड करती है। ईगर लोडिंग के उपयोग से प्राप्त किया जाता हैInclude method

इसका अर्थ है कि डेटाबेस से क्वेरी परिणामों के साथ संबंधित डेटा का अनुरोध किया जाना चाहिए। डेटा स्रोत के लिए केवल एक कनेक्शन बनाया गया है, प्रारंभिक क्वेरी में डेटा का एक बड़ा हिस्सा वापस किया जाता है।

उदाहरण के लिए, छात्रों को क्वेरी करते समय, अपने नामांकन को उत्सुकता से लोड करें। छात्रों और उनके नामांकन को एक ही प्रश्न में पुनः प्राप्त किया जाएगा।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें सभी छात्र अपने संबंधित नामांकन के साथ उत्सुक लोडिंग का उपयोग करके डेटाबेस से प्राप्त होते हैं।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {
         // Load all students and related enrollments
         var students = context.Students
            .Include(s ⇒ s.Enrollments).ToList();
			
         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

नीचे उत्सुक लोडिंग प्रश्नों के कुछ अन्य रूप दिए गए हैं जिनका उपयोग किया जा सकता है।

// Load one Student and its related enrollments

var student1 = context.Students
   .Where(s ⇒ s.FirstMidName == "Ali")
   .Include(s ⇒ s.Enrollments).FirstOrDefault();

// Load all Students and related enrollments
// using a string to specify the relationship

var studentList = context.Students
   .Include("Enrollments").ToList();

// Load one Student and its related enrollments
// using a string to specify the relationship

var student = context.Students
   .Where(s ⇒ s.FirstMidName == "Salman")
   .Include("Enrollments").FirstOrDefault();

एकाधिक स्तर

संबंधित संस्थाओं के कई स्तरों को उत्सुकता से लोड करना भी संभव है। निम्नलिखित प्रश्न छात्र, नामांकन और पाठ्यक्रम के उदाहरण दिखाते हैं।

// Load all Students, all related enrollments, and all related courses

var studentList = context.Students
   .Include(s ⇒ s.Enrollments.Select(c ⇒ c.Course)).ToList();

// Load all Students, all related enrollments, and all related courses
// using a string to specify the relationships

var students = context.Students
   .Include("Enrollments.Course").ToList();

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