एंटिटी फ्रेमवर्क - मॉडल प्रथम दृष्टिकोण

इस अध्याय में, आइए जानें कि पहले मॉडल के रूप में संदर्भित वर्कफ़्लो का उपयोग करके डिज़ाइनर में एक इकाई डेटा मॉडल कैसे बनाया जाए।

  • जब आप एक नया प्रोजेक्ट शुरू कर रहे हैं, जहां डेटाबेस अभी भी मौजूद नहीं है, तब मॉडल फर्स्ट बढ़िया है।

  • मॉडल को EDMX फ़ाइल में संग्रहीत किया जाता है और इसे एंटिटी फ्रेमवर्क डिज़ाइनर में देखा और संपादित किया जा सकता है।

  • मॉडल पहले में, आप अपने मॉडल को एक एंटिटी फ्रेमवर्क डिज़ाइनर में परिभाषित करते हैं, फिर SQL उत्पन्न करते हैं, जो आपके मॉडल से मेल खाने के लिए डेटाबेस स्कीमा बनाएगा और फिर आप अपने डेटाबेस में स्कीमा बनाने के लिए SQL को निष्पादित करते हैं।

  • आपके द्वारा अपने आवेदन में जिन वर्गों के साथ बातचीत की जाती है, वे ईडीएमएक्स फ़ाइल से स्वचालित रूप से उत्पन्न होती हैं।

मॉडल प्रथम दृष्टिकोण का उपयोग करके एक नया कंसोल प्रोजेक्ट बनाने का एक सरल उदाहरण निम्नलिखित है।

Step 1 - विजुअल स्टूडियो खोलें और फाइल → न्यू → प्रोजेक्ट चुनें

Step 2 - इंस्टाल्ड → टेम्प्लेट्स → विजुअल C # → विंडोज को लेफ्ट पेन से चुनें और फिर मिडिल पेन में, कंसोल एप्लीकेशन चुनें।

Step 3 - नाम फ़ील्ड में EFModelFirstDemo दर्ज करें।

Step 4 - मॉडल बनाने के लिए, पहले समाधान एक्सप्लोरर में अपने कंसोल प्रोजेक्ट पर राइट-क्लिक करें और Add → नई आइटम का चयन करें ...

निम्नलिखित संवाद खुल जाएगा।

Step 5 - मध्य फलक से ADO.NET इकाई डेटा मॉडल का चयन करें और नाम फ़ील्ड में नाम ModelFirstDemoDB दर्ज करें।

Step 6 - Add बटन पर क्लिक करें जो Entity Data Model Wizard डायलॉग लॉन्च करेगा।

Step 7- खाली ईएफ डिजाइनर मॉडल का चयन करें और अगला बटन पर क्लिक करें। एंटिटी फ्रेमवर्क डिज़ाइनर एक खाली मॉडल के साथ खुलता है। अब हम मॉडल में संस्थाओं, संपत्तियों और संघों को जोड़ना शुरू कर सकते हैं।

Step 8- डिज़ाइन की सतह पर राइट-क्लिक करें और गुण चुनें। गुण विंडो में, Entity कंटेनर का नाम बदलकर ModelFirstDemoDBContext करें।

Step 9 - डिज़ाइन की सतह पर राइट-क्लिक करें और Add New → Entity चुनें ...

Add Entity डायलॉग खुलेगा जैसा कि निचे दी गयी इमेज में दिखाया गया है।

Step 10 - छात्र का नाम और स्टूडेंट आईडी को संपत्ति के नाम के रूप में दर्ज करें और ओके पर क्लिक करें।

Step 11 - डिज़ाइन की सतह पर नई इकाई पर राइट-क्लिक करें और Add New → Scalar Property चुनें, संपत्ति के नाम के रूप में नाम दर्ज करें।

Step 12 - FirstName दर्ज करें और फिर LastName और EnrollmentDate जैसे अन्य दो अदिश गुण जोड़ें।

Step 13 - ऊपर बताए गए सभी चरणों का पालन करते हुए दो और Entities Course और Enrolment जोड़ें और साथ ही निम्नलिखित चरणों में दिखाए गए अनुसार कुछ Scalar गुण जोड़ें।

Step 14 - हमारे पास विज़ुअल डिज़ाइनर में तीन इकाइयाँ हैं, चलो उनके बीच कुछ जुड़ाव या संबंध जोड़ते हैं।

Step 15 - डिज़ाइन की सतह पर राइट-क्लिक करें और Add New → Association… का चयन करें

Step 16 - छात्र के संबंध के एक छोर को एक की बहुलता के साथ और दूसरे के अंत को कई की बहुलता के साथ नामांकन का बिंदु बनाएं।

Step 17 - इसका मतलब है कि एक छात्र के पास कई नामांकन हैं और नामांकन एक छात्र का है।

Step 18 - सुनिश्चित करें कि 'पोस्ट' एंटिटी बॉक्स में विदेशी कुंजी गुण जोड़ें और ठीक पर क्लिक करें।

Step 19 - इसी तरह, कोर्स और एनरोलमेंट के बीच एक और जुड़ाव जोड़ें।

Step 20 - आपका डेटा मॉडल संस्थाओं के बीच संघों को जोड़ने के बाद निम्न स्क्रीन की तरह दिखेगा।

अब हमारे पास एक सरल मॉडल है जिसे हम डेटा पढ़ने और लिखने के लिए एक डेटाबेस से उत्पन्न कर सकते हैं और उपयोग कर सकते हैं। चलो आगे बढ़ते हैं और डेटाबेस उत्पन्न करते हैं।

Step 1 - डिज़ाइन की सतह पर राइट-क्लिक करें और मॉडल से Generate डेटाबेस चुनें ...

Step 2 - आप मौजूदा डेटाबेस का चयन कर सकते हैं या नए कनेक्शन पर क्लिक करके एक नया कनेक्शन बना सकते हैं ...

Step 3 - नया डेटाबेस बनाने के लिए, नए कनेक्शन पर क्लिक करें ...

Step 4 - सर्वर का नाम और डेटाबेस का नाम दर्ज करें।

Step 5 - अगला।

Step 6- नीचे क्लिक करें। यह प्रोजेक्ट में * .edmx.sql फ़ाइल जोड़ेगा। आप .sql फ़ाइल खोलकर Visual Studio में DDL स्क्रिप्ट निष्पादित कर सकते हैं, फिर राइट क्लिक करें और Execute चुनें।

Step 7 - डेटाबेस से कनेक्ट करने के लिए निम्न संवाद प्रदर्शित किया जाएगा।

Step 8 - सफल निष्पादन पर, आप निम्नलिखित संदेश देखेंगे।

Step 9 - सर्वर एक्सप्लोरर पर जाएं, आप देखेंगे कि डेटाबेस तीन तालिकाओं के साथ बनाया गया है जो निर्दिष्ट हैं।

अगला, हमें अपने मॉडल को कोड उत्पन्न करने के लिए स्वैप करना होगा जो DbContext API का उपयोग करता है।

Step 1 - EF डिज़ाइनर में अपने मॉडल के खाली स्थान पर राइट-क्लिक करें और Add Code Generation Item… चुनें

आप देखेंगे कि निम्न नया आइटम जोड़ें संवाद खुलता है।

Step 2 - मध्य फलक में EF 6.x DbContext जनरेटर चुनें और Name फील्ड में ModelFirstDemoModel डालें।

Step 3 - आप अपने समाधान एक्सप्लोरर में देखेंगे कि ModelFirstDemoModel.Context.tt और ModelFirstDemoModel.tt टेम्प्लेट उत्पन्न होते हैं।

ModelFirstDemoModel.Context DbCcontext और ऑब्जेक्ट सेट करता है जिसे आप वापस भेज सकते हैं और क्वेरी के लिए उपयोग कर सकते हैं, संदर्भ के लिए कह सकते हैं, छात्र और पाठ्यक्रम आदि।

अन्य टेम्पलेट सभी प्रकार के छात्रों, पाठ्यक्रमों आदि से संबंधित है। निम्नलिखित छात्र वर्ग है, जो इकाई मॉडल से स्वचालित रूप से उत्पन्न होता है।

निम्नलिखित सी # कोड है जिसमें कुछ डेटा दर्ज किए जाते हैं और डेटाबेस से पुनर्प्राप्त किए जाते हैं।

using System;
using System.Linq;

namespace EFModelFirstDemo {

   class Program {

      static void Main(string[] args) {

         using (var db = new ModelFirstDemoDBContext()) {

            // Create and save a new Student

            Console.Write("Enter a name for a new Student: ");
            var firstName = Console.ReadLine();

            var student = new Student {
               StudentID = 1,
               FirstName = firstName
            };
				
            db.Students.Add(student);
            db.SaveChanges();
				
            var query = from b in db.Students
               orderby b.FirstName select b;

            Console.WriteLine("All student in the database:");

            foreach (var item in query) {
               Console.WriteLine(item.FirstName);
            }

            Console.WriteLine("Press any key to exit...");
            Console.ReadKey();
         }
      }
   }
}

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

Enter a name for a new Student:
Ali Khan
All student in the database:
Ali Khan
Press any key to exit...

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