इकाई फ्रेमवर्क - दृढ़ता
एंटिटी फ्रेमवर्क अब आपको एंटिटी फ्रेमवर्क से अवगत कराने के लिए एंटिटी फ्रेमवर्क से लाभ उठाने की अनुमति देता है, एंटिटी फ्रेमवर्क से अवगत होने के लिए, संस्थाओं को बुनियादी ढांचे से अलग करना। आप ऐसी कक्षाएं बना सकते हैं जो उनके व्यावसायिक नियमों पर ध्यान केंद्रित किए बिना बता सकती हैं कि वे कैसे बनी रहती हैं (जहां डेटा संग्रहीत किया जाता है और आपकी वस्तुओं के बीच डेटा आगे-पीछे कैसे होता है)।
लगातार अज्ञानी संस्थाओं का निर्माण
पूर्ववर्ती पैराग्राफ ने एक ऐसी विधि का वर्णन किया जिसमें डेटा के स्रोत का कोई अंतरंग ज्ञान नहीं है जो वह खपत करता है। यह दृढ़ता अज्ञानता के सार को उजागर करता है, जो तब होता है जब आपकी कक्षाएं और उनके आसपास हमारे कई एप्लिकेशन परतें परवाह नहीं करती हैं कि डेटा कैसे संग्रहीत किया जाता है।
एंटिटी फ्रेमवर्क के .NET 3.5 संस्करण में, यदि आप preexisting कक्षाओं का उपयोग करना चाहते हैं, तो आपको EntityObject से उन्हें प्राप्त करने के लिए मजबूर करके उन्हें संशोधित करना आवश्यक था।
.NET 4 में यह अब आवश्यक नहीं है। एंटिटी फ्रेमवर्क संचालन में भाग लेने के लिए आपको अपनी संस्थाओं को संशोधित करने की आवश्यकता नहीं है।
यह हमें उन अनुप्रयोगों का निर्माण करने की अनुमति देता है जो ढीले युग्मन और चिंताओं के अलगाव को गले लगाते हैं।
इन कोडिंग पैटर्न के साथ, आपकी कक्षाएं केवल अपनी नौकरियों से संबंधित हैं और, यूआई सहित आपके आवेदन की कई परतों में बाहरी तर्क पर निर्भरता नहीं है, जैसे कि एंटिटी फ्रेमवर्क एपीआई, फिर भी वे बाहरी एपीआई हमारे साथ बातचीत करने में सक्षम हैं। संस्थाओं।
एंटिटी फ्रेमवर्क के साथ एक इकाई कायम करते समय 2 तरीके (जुड़े और डिस्कनेक्ट किए गए) हैं। दोनों ही तरीकों का अपना महत्व है। एक जुड़े हुए परिदृश्य के मामले में परिवर्तन को संदर्भ द्वारा ट्रैक किया जाता है, लेकिन डिस्कनेक्ट किए गए परिदृश्य के मामले में हमें इकाई की स्थिति के बारे में संदर्भ को सूचित करना होगा।
जुड़े हुए दृश्य
जुड़ा हुआ परिदृश्य तब होता है जब एक इकाई डेटाबेस से पुनर्प्राप्त की जाती है और उसी संदर्भ में संशोधित होती है। एक जुड़े हुए परिदृश्य के लिए मान लें कि हमारे पास एक Windows सेवा है और हम उस इकाई के साथ कुछ व्यावसायिक कार्य कर रहे हैं, इसलिए हम सभी संस्थाओं के माध्यम से संदर्भ, लूप खोलेंगे, हमारे व्यवसाय का संचालन करेंगे और फिर उसी संदर्भ के साथ परिवर्तनों को सहेजेंगे जो हम शुरुआत में खोला गया।
आइए निम्नलिखित उदाहरणों पर एक नज़र डालें जिसमें छात्रों को डेटाबेस से पुनर्प्राप्त किया जाता है और छात्रों के पहले नाम को अपडेट करते हैं और फिर डेटाबेस में परिवर्तन को सहेजते हैं।
class Program {
static void Main(string[] args) {
using (var context = new MyContext()) {
var studentList = context.Students.ToList();
foreach (var stdnt in studentList) {
stdnt.FirstMidName = "Edited " + stdnt.FirstMidName;
}
context.SaveChanges();
//// Display all Students from the database
var students = (from s in context.Students
orderby s.FirstMidName select s).ToList<Student>();
Console.WriteLine("Retrieve all Students from the database:");
foreach (var stdnt in students) {
string name = stdnt.FirstMidName + " " + stdnt.LastName;
Console.WriteLine("ID: {0}, Name: {1}", stdnt.ID, name);
}
Console.ReadKey();
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा और आप देखेंगे कि संपादित नाम पहले नाम से पहले संलग्न है जैसा कि निम्नलिखित आउटपुट में दिखाया गया है।
Retrieve all Students from the database:
ID: 1, Name: Edited Edited Alain Bomer
ID: 2, Name: Edited Edited Mark Upston
असम्बद्ध परिदृश्य
असंबद्ध परिदृश्य तब होता है जब एक इकाई डेटाबेस से पुनर्प्राप्त की जाती है और विभिन्न संदर्भों में संशोधित की जाती है। मान लीजिए कि हम एक प्रस्तुति परत में कुछ डेटा प्रदर्शित करना चाहते हैं और हम कुछ एन-टियर एप्लिकेशन का उपयोग कर रहे हैं, इसलिए संदर्भ को खोलना, डेटा प्राप्त करना और अंत में संदर्भ को बंद करना बेहतर होगा। चूंकि यहां हमने डेटा प्राप्त किया है और संदर्भ को बंद कर दिया है, जिन संस्थाओं को हमने लिया है वे अब ट्रैक नहीं किए गए हैं और यह डिस्कनेक्ट परिदृश्य है।
आइए निम्नलिखित कोड पर एक नज़र डालें, जिसमें Add method का उपयोग करके नए डिस्कनेक्टेड छात्र इकाई को एक संदर्भ में जोड़ा गया है।
class Program {
static void Main(string[] args) {
var student = new Student {
ID = 1001,
FirstMidName = "Wasim",
LastName = "Akram",
EnrollmentDate = DateTime.Parse( DateTime.Today.ToString())
};
using (var context = new MyContext()) {
context.Students.Add(student);
context.SaveChanges();
//// Display all Students from the database
var students = (from s in context.Students
orderby s.FirstMidName select s).ToList<Student>();
Console.WriteLine("Retrieve all Students from the database:");
foreach (var stdnt in students) {
string name = stdnt.FirstMidName + " " + stdnt.LastName;
Console.WriteLine("ID: {0}, Name: {1}", stdnt.ID, name);
}
Console.ReadKey();
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा।
Retrieve all Students from the database:
ID: 1, Name: Edited Edited Edited Alain Bomer
ID: 2, Name: Edited Edited Edited Mark Upston
ID: 3, Name: Wasim Akram