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