एंटिटी फ्रेमवर्क - क्विक गाइड

एंटिटी फ्रेमवर्क क्या है?

एंटिटी फ्रेमवर्क को पहली बार 2008 में जारी किया गया था। Microsoft का मुख्य अर्थ .NET अनुप्रयोगों और संबंधपरक डेटाबेस के बीच बातचीत करना है। एंटिटी फ्रेमवर्क एक ऑब्जेक्ट रिलेशनल मैपर (ORM) है, जो एक प्रकार का टूल है, जो आपके सॉफ़्टवेयर में ऑब्जेक्ट्स के बीच मैपिंग को एक रिलेशनल डेटाबेस के टेबल और कॉलम के लिए सरल करता है।

  • एंटिटी फ्रेमवर्क (EF) ADO.NET के लिए एक ओपन सोर्स ORM फ्रेमवर्क है जो .NET फ्रेमवर्क का एक हिस्सा है।

  • एक ORM डेटाबेस कनेक्शन बनाने और कमांड निष्पादित करने के साथ-साथ क्वेरी परिणाम लेने और उन परिणामों को स्वचालित रूप से आपके एप्लिकेशन ऑब्जेक्ट के रूप में भौतिक बनाने का ख्याल रखता है।

  • एक ORM उन वस्तुओं में परिवर्तनों पर नज़र रखने में मदद करता है, और जब निर्देश दिया जाता है, तो यह उन परिवर्तनों को आपके लिए डेटाबेस में वापस भी बनाए रखेगा।

इकाई ढांचा क्यों?

एंटिटी फ्रेमवर्क एक ORM है और ORM का उद्देश्य अनुप्रयोगों में उपयोग किए गए डेटा को जारी रखने के निरर्थक कार्य को कम करके डेवलपर की उत्पादकता को बढ़ाना है।

  • एंटिटी फ्रेमवर्क डेटाबेस में डेटा पढ़ने या लिखने के लिए आवश्यक डेटाबेस कमांड उत्पन्न कर सकता है और आपके लिए उन्हें निष्पादित कर सकता है।

  • यदि आप क्वेरी कर रहे हैं, तो आप LINQ का उपयोग करके अपने डोमेन ऑब्जेक्ट्स के विरुद्ध अपनी क्वेरी को व्यक्त कर सकते हैं।

  • एंटिटी फ्रेमवर्क डेटाबेस में संबंधित क्वेरी को निष्पादित करेगा और फिर आपको अपने ऐप के भीतर काम करने के लिए अपने डोमेन ऑब्जेक्ट के उदाहरणों में परिणाम देगा।

बाज़ार में अन्य ORM हैं जैसे NHibernate और LLBLGen Pro। ज्यादातर ORM आमतौर पर डोमेन स्कीमा को सीधे डेटाबेस स्कीमा में मैप करते हैं।

इकाई फ्रेमवर्क में एक अधिक दानेदार मानचित्रण परत होती है जिससे आप मैपिंग को अनुकूलित कर सकते हैं, उदाहरण के लिए एकल इकाई को एक से अधिक डेटाबेस तालिकाओं या यहां तक ​​कि कई संस्थाओं को एक ही तालिका में मैप करके।

  • एंटिटी फ्रेमवर्क नए अनुप्रयोगों के लिए Microsoft की अनुशंसित डेटा एक्सेस तकनीक है।

  • ADO.NET डेटा सेट और डेटा टेबल के लिए सीधे प्रौद्योगिकी को संदर्भित करता है।

  • एंटिटी फ्रेमवर्क वह जगह है जहां सभी आगे बढ़ने वाले निवेश किए जा रहे हैं, जो कि कई वर्षों से पहले से ही है।

  • Microsoft अनुशंसा करता है कि आप सभी नए विकास के लिए ADO.NET या LINQ से SQL पर Entity फ्रेमवर्क का उपयोग करें।

वैचारिक प्रतिरूप

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

  • एंटिटी फ्रेमवर्क के साथ, केंद्र बिंदु को एक वैचारिक मॉडल के रूप में संदर्भित किया जाता है। यह आपके एप्लिकेशन में ऑब्जेक्ट्स का एक मॉडल है, न कि उस डेटाबेस का एक मॉडल जो आप अपने एप्लिकेशन डेटा को बनाए रखने के लिए उपयोग करते हैं।

  • आपका वैचारिक मॉडल आपके डेटाबेस स्कीमा के साथ संरेखित करने के लिए हो सकता है या यह काफी भिन्न हो सकता है।

  • आप अपने वैचारिक मॉडल को परिभाषित करने के लिए एक दृश्य डिजाइनर का उपयोग कर सकते हैं, जो तब आपके द्वारा अपने आवेदन में उपयोग की जाने वाली कक्षाओं को उत्पन्न कर सकता है।

  • आप बस अपनी कक्षाओं को परिभाषित कर सकते हैं और एंटिटी फ्रेमवर्क की एक सुविधा का उपयोग कर सकते हैं जिसे कोड फर्स्ट कहा जाता है। और फिर एंटिटी फ्रेमवर्क वैचारिक मॉडल को समझेगा।

किसी भी तरह से, एंटिटी फ्रेमवर्क यह बताता है कि आपके वैचारिक मॉडल से अपने डेटाबेस में कैसे जाना है। तो, आप अपने वैचारिक मॉडल ऑब्जेक्ट के खिलाफ क्वेरी कर सकते हैं और सीधे उनके साथ काम कर सकते हैं।

विशेषताएं

एंटिटी फ्रेमवर्क की बुनियादी विशेषताएं निम्नलिखित हैं। यह सूची सबसे उल्लेखनीय विशेषताओं के आधार पर बनाई गई है और एंटिटी फ्रेमवर्क के बारे में अक्सर पूछे जाने वाले प्रश्नों से भी।

  • Entity Framework एक Microsoft उपकरण है।
  • एंटिटी फ्रेमवर्क को ओपन सोर्स प्रोडक्ट के रूप में विकसित किया जा रहा है।
  • एंटिटी फ्रेमवर्क अब .NET रिलीज चक्र से बंधा या निर्भर नहीं है।
  • वैध एंटिटी फ्रेमवर्क प्रदाता के साथ किसी भी संबंधपरक डेटाबेस के साथ काम करता है।
  • LINQ से Entities तक SQL कमांड जनरेशन।
  • इकाई ढाँचा मानकीकृत क्वेरी बनाएगा।
  • मेमोरी-ऑब्जेक्ट्स में परिवर्तन ट्रैक करता है।
  • कमांड पीढ़ी को सम्मिलित करने, अपडेट करने और हटाने की अनुमति देता है।
  • एक दृश्य मॉडल के साथ या अपनी कक्षाओं के साथ काम करता है।
  • इकाई फ्रेमवर्क ने प्रक्रिया प्रक्रिया को संग्रहीत किया है।

एंटिटी फ्रेमवर्क का आर्किटेक्चर, नीचे से ऊपर, निम्नलिखित में से हैं -

डेटा प्रदाता

ये स्रोत विशिष्ट प्रदाता हैं, जो वैचारिक स्कीमा के खिलाफ प्रोग्रामिंग करते समय डेटाबेस से जुड़ने के लिए ADO.NET इंटरफेस को अमूर्त करते हैं।

यह सामान्य SQL भाषाओं जैसे LINQ को कमांड ट्री के माध्यम से देशी SQL अभिव्यक्ति में अनुवाद करता है और इसे विशिष्ट DBMS सिस्टम के खिलाफ निष्पादित करता है।

इकाई ग्राहक

यह परत इकाई परत को ऊपरी परत में उजागर करती है। एंटिटी क्लाइंट डेवलपर्स के लिए वैचारिक स्कीमा का प्रतिनिधित्व करने के लिए कक्षाएं उत्पन्न करने की आवश्यकता के बिना इकाई एसक्यूएल प्रश्नों का उपयोग करके पंक्तियों और स्तंभों के रूप में संस्थाओं के खिलाफ काम करने की क्षमता प्रदान करता है। इकाई ग्राहक इकाई ढांचे की परतें दिखाता है, जो मुख्य कार्यक्षमता हैं। इन परतों को एंटिटी डेटा मॉडल कहा जाता है।

  • Storage Layer XML स्वरूप में संपूर्ण डेटाबेस स्कीमा शामिल है।

  • Entity Layer जो एक्सएमएल फाइल भी है, वह संस्थाओं और रिश्तों को परिभाषित करता है।

  • Mapping layer एक XML फ़ाइल है जो तार्किक परत पर परिभाषित वास्तविक संबंधों और तालिकाओं के साथ वैचारिक परत पर परिभाषित संस्थाओं और संबंधों को मैप करती है।

  • Metadata services जिसे एंटिटी क्लाइंट में भी दर्शाया गया है, मेटाडेटा संग्रहित एंटिटी, मैपिंग और स्टोरेज परतों तक पहुँचने के लिए केंद्रीकृत एपीआई प्रदान करता है।

वस्तु सेवा

ऑब्जेक्ट सर्विसेज लेयर ऑब्जेक्ट कॉनटेक्स्ट है, जो अनुप्रयोगों और डेटा स्रोत के बीच बातचीत के सत्र का प्रतिनिधित्व करता है।

  • ऑब्जेक्ट कॉन्टेक्स्ट का मुख्य उपयोग ऐड्स, इंस्टीट्यूशंस के इंस्टेंट्स को डिलीट करने और क्वेरी की मदद से बदले हुए स्टेट्स को डेटाबेस में वापस सेव करने के लिए अलग-अलग ऑपरेशन करना है।

  • यह इकाई फ्रेमवर्क की ORM परत है, जो संस्थाओं के ऑब्जेक्ट इंस्टेंस के डेटा परिणाम का प्रतिनिधित्व करती है।

  • यह सेवाएं डेवलपर को LINQ और Entre SQL का उपयोग करके प्रश्न लिखकर प्राथमिक कुंजी मैपिंग, परिवर्तन ट्रैकिंग आदि जैसी कुछ समृद्ध ORM सुविधाओं का उपयोग करने की अनुमति देती हैं।

एंटिटी फ्रेमवर्क 6 में नया क्या है?

फ्रेमवर्क का एक जटिल एपीआई है जो आपको मॉडलिंग से लेकर उसके रनटाइम व्यवहार तक सब पर नियंत्रण रखता है। एंटिटी फ्रेमवर्क 5 का एक हिस्सा .NET के अंदर रहता है। और इसका एक और हिस्सा एक अतिरिक्त विधानसभा के अंदर रहता है जिसे NuGet का उपयोग करके वितरित किया जाता है।

  • एंटिटी फ्रेमवर्क की मुख्य कार्यक्षमता .NET फ्रेमवर्क में बनाई गई है।

  • कोड फर्स्ट सपोर्ट, यही एंटिटी फ्रेमवर्क एक विजुअल मॉडल के एवज में कक्षाओं का उपयोग करने की सुविधा देता है, और EF के साथ बातचीत के लिए एक हल्का तरीका API NuGet पैकेज में है।

  • कोर वह है जो क्वेरी, परिवर्तन ट्रैकिंग और आपके प्रश्नों से SQL क्वेरी के साथ-साथ डेटा रिटर्न से ऑब्जेक्ट में परिवर्तन के सभी प्रदान करता है।

  • आप .NET 4 और .NET 4.5 के साथ EF 5 NuGet पैकेज का उपयोग कर सकते हैं।

  • भ्रम का एक बड़ा बिंदु - .NET 4.5 ने कोर एंटिटी फ्रेमवर्क एपीआई के लिए एनम और स्थानिक डेटा के लिए समर्थन जोड़ा, जिसका अर्थ है कि यदि आप .NET 4 के साथ ईएफ 5 का उपयोग कर रहे हैं, तो आपको ये नई सुविधाएं नहीं मिलेंगी। .NET 4.5 के साथ EF5 को मिलाते समय आप केवल उन्हें प्राप्त करेंगे।

आइए अब हम एंटिटी फ्रेमवर्क पर एक नज़र डालते हैं। कोर एपीआई जो एंटिटी फ्रेमवर्क 6 में .NET के अंदर थे, अब NuGet पैकेज का एक हिस्सा हैं।

इसका मतलब है -

  • एंटिटी फ्रेमवर्क के सभी रहता है कि इस विधानसभा को NuGet द्वारा वितरित किया जाता है

  • आप Entity Framework enum समर्थन और विशेष डेटा समर्थन जैसी विशिष्ट सुविधाएँ प्रदान करने के लिए .NET पर निर्भर नहीं होंगे।

  • आप देखेंगे कि EF6 की एक विशेषता यह है कि यह .NET 4 के लिए enums और स्थानिक डेटा का समर्थन करता है

एंटिटी फ्रेमवर्क पर काम शुरू करने के लिए आपको निम्नलिखित विकास उपकरण स्थापित करने होंगे -

  • दृश्य स्टूडियो 2013 या इसके बाद के संस्करण
  • SQL सर्वर 2012 या इसके बाद के संस्करण
  • नुगेट पैकेज से एंटिटी फ्रेमवर्क अपडेट

Microsoft दृश्य स्टूडियो का एक निःशुल्क संस्करण प्रदान करता है जिसमें SQL सर्वर भी होता है और इसे www.visualstudio.com से डाउनलोड किया जा सकता है ।

इंस्टालेशन

Step 1- डाउनलोड पूरा होने के बाद इंस्टॉलर को चलाएं। निम्नलिखित संवाद प्रदर्शित किया जाएगा।

Step 2 - इंस्टॉल बटन पर क्लिक करें और यह इंस्टॉलेशन प्रक्रिया शुरू कर देगा।

Step 3- एक बार इंस्टॉलेशन प्रक्रिया सफलतापूर्वक पूरी हो जाने के बाद, आप निम्नलिखित संवाद देखेंगे। इस संवाद को बंद करें और यदि आवश्यक हो तो अपने कंप्यूटर को पुनरारंभ करें।

Step 4- स्टार्ट मेनू से विजुअल स्टूडियो खोलें जो निम्नलिखित डायलॉग खोलेगा। तैयारी के लिए पहली बार कुछ समय होगा।

Step 5 - सब कुछ हो जाने के बाद आप विजुअल स्टूडियो की मुख्य विंडो देखेंगे।

चलिए File → New → Project से एक नया प्रोजेक्ट बनाते हैं

Step 1 - कंसोल एप्लिकेशन चुनें और ओके बटन पर क्लिक करें।

Step 2 - समाधान एक्सप्लोरर में, अपनी परियोजना पर राइट-क्लिक करें।

Step 3 - उपरोक्त छवि में दिखाए अनुसार प्रबंधित NuGet संकुल का चयन करें, जो विज़ुअल स्टूडियो में निम्न विंडो को खोलेगा।

Step 4 - एंटिटी फ्रेमवर्क की खोज करें और इंस्टॉल बटन दबाकर नवीनतम संस्करण स्थापित करें।

Step 5- क्लिक करें। एक बार इंस्टॉलेशन हो जाने के बाद, आप अपने आउटपुट विंडो में निम्न संदेश देखेंगे।

अब आप अपना आवेदन शुरू करने के लिए तैयार हैं।

इस ट्यूटोरियल में, हम एक साधारण यूनिवर्सिटी डेटाबेस का उपयोग करेंगे। एक विश्वविद्यालय डेटाबेस एक पूरे के रूप में बहुत अधिक जटिल हो सकता है लेकिन डेमो और सीखने के उद्देश्य के लिए, हम इस डेटाबेस के सबसे सरल रूप का उपयोग कर रहे हैं। निम्न आरेख में तीन तालिकाएँ हैं।

  • Student
  • Course
  • Enrollment

जब भी एक टर्म डेटाबेस का उपयोग किया जाता है तो एक चीज सीधे हमारे दिमाग में आती है और वह है अलग-अलग तरह की टेबल्स जिनमें किसी प्रकार का संबंध होता है। तालिकाओं के बीच तीन प्रकार के संबंध हैं और विभिन्न तालिकाओं के बीच संबंध इस बात पर निर्भर करता है कि संबंधित स्तंभ कैसे परिभाषित किए जाते हैं।

  • एक से कई रिश्ते
  • कई-कई रिश्ते
  • वन-टू-वन रिलेशनशिप

एक से कई रिश्ते

एक से कई रिश्ते सबसे आम प्रकार का रिश्ता है। इस प्रकार के संबंधों में, तालिका A में तालिका B में कई मिलान पंक्तियाँ हो सकती हैं, लेकिन तालिका B में एक पंक्ति में तालिका A में केवल एक मिलान पंक्ति हो सकती है। उदाहरण के लिए, उपरोक्त आरेख में, छात्र और नामांकन तालिका में एक है -कई रिश्ते में, प्रत्येक छात्र के कई नामांकन हो सकते हैं, लेकिन प्रत्येक नामांकन केवल एक छात्र का है।

कई-कई रिश्ते

कई-से-कई संबंधों में, तालिका ए में एक पंक्ति में तालिका बी में कई मिलान पंक्तियाँ हो सकती हैं, और इसके विपरीत। आप तीसरी तालिका को परिभाषित करके एक ऐसा संबंध बनाते हैं, जिसे जंक्शन तालिका कहा जाता है, जिसकी प्राथमिक कुंजी में तालिका A और तालिका B दोनों से विदेशी कुंजियाँ होती हैं। उदाहरण के लिए, छात्र और पाठ्यक्रम तालिका में कई-से-कई संबंध होते हैं जिन्हें परिभाषित किया जाता है इन तालिकाओं में से प्रत्येक से एनरोलमेंट टेबल तक एक-से-कई संबंध।

वन-टू-वन रिलेशनशिप

एक-से-एक रिश्ते में, तालिका ए में एक पंक्ति में तालिका बी में एक से अधिक मिलान पंक्ति नहीं हो सकती है, और इसके विपरीत। एक-से-एक संबंध बनाया जाता है यदि दोनों संबंधित स्तंभ प्राथमिक कुंजी हैं या अद्वितीय अवरोध हैं।

इस प्रकार का संबंध सामान्य नहीं है क्योंकि इस तरह से संबंधित अधिकांश जानकारी एक-से-एक तालिका में होगी। आप एक-से-एक संबंध का उपयोग कर सकते हैं -

  • कई स्तंभों के साथ एक तालिका को विभाजित करें।
  • सुरक्षा कारणों से एक तालिका का अलग भाग।
  • स्टोर डेटा जो अल्पकालिक है और आसानी से तालिका को हटाकर आसानी से हटाया जा सकता है।
  • ऐसी जानकारी संग्रहीत करें जो केवल मुख्य तालिका के सबसेट पर लागू होती है।

Entity Data Model (EDM) Entity-Relationship मॉडल का एक विस्तारित संस्करण है जो विभिन्न मॉडलिंग तकनीक का उपयोग करके डेटा के वैचारिक मॉडल को निर्दिष्ट करता है। यह अवधारणाओं के एक सेट को भी संदर्भित करता है जो डेटा संरचना का वर्णन करता है, भले ही इसके संग्रहीत रूप की परवाह किए बिना।

ईडीएम आदिम डेटा प्रकारों के एक सेट का समर्थन करता है जो एक वैचारिक मॉडल में गुणों को परिभाषित करते हैं। हमें 3 मुख्य भागों पर विचार करने की आवश्यकता है, जो एंटिटी फ्रेमवर्क के लिए आधार बनाते हैं और सामूहिक रूप से इसे एंटिटी डेटा मॉडल के रूप में जाना जाता है। ईडीएम के तीन मुख्य भाग निम्नलिखित हैं।

  • संग्रहण स्कीमा मॉडल
  • वैचारिक मॉडल
  • मैपिंग मॉडल

संग्रहण स्कीमा मॉडल

स्टोरेज मॉडल जिसे स्टोरेज स्कीमा डेफिनेशन लेयर (SSDL) भी कहा जाता है, बैकएंड डेटा स्टोर के योजनाबद्ध प्रतिनिधित्व का प्रतिनिधित्व करता है।

वैचारिक मॉडल

वैचारिक मॉडल जिसे कॉन्सेप्चुअल स्कीमा डेफिनिशन लेयर (CSDL) भी कहा जाता है, वास्तविक इकाई मॉडल है, जिसके विरुद्ध हम अपने प्रश्न लिखते हैं।

मैपिंग मॉडल

मैपिंग लेयर कंसेप्चुअल मॉडल और स्टोरेज मॉडल के बीच एक मैपिंग है।

तार्किक स्कीमा और भौतिक स्कीमा के साथ इसकी मैपिंग को ईडीएम के रूप में दर्शाया गया है।

  • विज़ुअल स्टूडियो ईडीएम के दृश्य निर्माण और मैपिंग विनिर्देशन के लिए, एंटिटी डिज़ाइनर भी प्रदान करता है।

  • टूल का आउटपुट XML फ़ाइल (* .edmx) है जो स्कीमा और मैपिंग को निर्दिष्ट करता है।

  • Edmx फ़ाइल में Entity Framework मेटाडेटा कलाकृतियाँ हैं।

स्कीमा परिभाषा भाषा

ADO.NET इकाई फ्रेमवर्क EDM स्कीमा को परिभाषित करने के लिए स्कीमा परिभाषा भाषा (SDL) नामक XML आधारित डेटा परिभाषा भाषा का उपयोग करता है।

  • SDL अन्य आदिम प्रकारों के समान सरल प्रकारों को परिभाषित करता है, जिसमें String, Int32, Double, Decimal और DateTime सहित अन्य शामिल हैं।

  • एक गणन, जो कि आदिम मूल्यों और नामों के मानचित्र को परिभाषित करता है, को भी एक सरल प्रकार माना जाता है।

  • गणना केवल फ्रेमवर्क संस्करण 5.0 के बाद से समर्थित हैं।

  • जटिल प्रकार अन्य प्रकारों के एकत्रीकरण से बनाए जाते हैं। इन प्रकारों के गुणों का एक संग्रह एक इकाई प्रकार को परिभाषित करता है।

डेटा मॉडल में मुख्य रूप से डेटा संरचना का वर्णन करने के लिए तीन प्रमुख अवधारणाएँ हैं -

  • इकाई प्रकार
  • एसोसिएशन का प्रकार
  • Property

इकाई प्रकार

ईडीएम में डेटा की संरचना का वर्णन करने के लिए इकाई प्रकार मौलिक बिल्डिंग ब्लॉक है।

  • एक वैचारिक मॉडल में, इकाई प्रकार गुणों से निर्मित होते हैं और एक व्यावसायिक अनुप्रयोग में छात्रों और नामांकन जैसे शीर्ष-स्तरीय अवधारणाओं की संरचना का वर्णन करते हैं।

  • एक इकाई एक विशिष्ट वस्तु का प्रतिनिधित्व करती है जैसे विशिष्ट छात्र या नामांकन।

  • प्रत्येक इकाई में एक इकाई सेट के भीतर एक अद्वितीय इकाई कुंजी होनी चाहिए। एक इकाई सेट एक विशिष्ट इकाई प्रकार के उदाहरणों का एक संग्रह है। इकाई सेट (और एसोसिएशन सेट) तार्किक रूप से एक इकाई कंटेनर में समूहीकृत होते हैं।

  • अनुवांशिकता को इकाई प्रकारों के साथ समर्थित किया जाता है, अर्थात एक इकाई प्रकार दूसरे से लिया जा सकता है।

एसोसिएशन का प्रकार

यह ईडीएम में संबंधों का वर्णन करने के लिए एक और बुनियादी इमारत ब्लॉक है। एक वैचारिक मॉडल में, एक संघ दो इकाई प्रकार जैसे कि छात्र और नामांकन के बीच एक संबंध का प्रतिनिधित्व करता है।

  • प्रत्येक एसोसिएशन में दो एसोसिएशन अंत होते हैं जो एसोसिएशन में शामिल इकाई प्रकारों को निर्दिष्ट करते हैं।

  • प्रत्येक एसोसिएशन का अंत भी एक एसोसिएशन एंड मल्टीफैलिटी को निर्दिष्ट करता है जो एसोसिएशन के उस छोर पर हो सकने वाली संस्थाओं की संख्या को इंगित करता है।

  • एक एसोसिएशन अंत बहुलता में एक (1), शून्य या एक (0..1), या कई (*) का मान हो सकता है।

  • एक संस्था के एक छोर पर स्थित संस्थाओं को नेविगेशन गुणों के माध्यम से, या विदेशी कुंजी के माध्यम से पहुँचा जा सकता है यदि वे एक इकाई प्रकार पर उजागर होते हैं।

संपत्ति

इकाई प्रकार में ऐसे गुण होते हैं जो उनकी संरचना और विशेषताओं को परिभाषित करते हैं। उदाहरण के लिए, एक छात्र इकाई प्रकार में छात्र आईडी, नाम आदि जैसे गुण हो सकते हैं।

एक संपत्ति में आदिम डेटा (जैसे कि एक स्ट्रिंग, एक पूर्णांक या एक बूलियन मान) या संरचित डेटा (जैसे कि एक जटिल प्रकार) हो सकता है।

एंटिटी फ्रेमवर्क आपको कॉमन लैंग्वेज रनटाइम (CLR) ऑब्जेक्ट्स के लिए डेटा को क्वेरी, इंसर्ट, अपडेट और डिलीट करने में सक्षम बनाता है, जो कि एंटिटीज के लिए जाना जाता है। एंटिटी फ्रेमवर्क उन संस्थाओं और रिश्तों को दर्शाता है जो आपके मॉडल में एक डेटाबेस में परिभाषित हैं। यह भी सुविधाएं प्रदान करता है -

  • डेटाबेस ऑब्जेक्ट से ऑब्जेक्ट के रूप में लौटाया गया डेटााइज़ करें
  • वस्तुओं में किए गए परिवर्तनों को ट्रैक करें
  • संभालना संगति
  • प्रोपेगेट ऑब्जेक्ट डेटाबेस में वापस बदल जाता है
  • वस्तुओं को नियंत्रित करने के लिए बांधें

प्राथमिक वर्ग जो वस्तुओं के रूप में डेटा के साथ बातचीत के लिए जिम्मेदार है, System.Data.Entity.DbContext है। DbContext API .NET फ्रेमवर्क के भाग के रूप में जारी नहीं किया गया है। कोड फ़र्स्ट और DbContext API में नई सुविधाओं को जारी करने के साथ अधिक लचीला और लगातार होने के लिए, Entity Framework टीम Microsoft के NuGet वितरण सुविधा के माध्यम से EntityFramework.dll वितरित करती है।

  • NuGet आपको वेब से सीधे अपने प्रोजेक्ट में प्रासंगिक DLL खींचकर अपने .NET प्रोजेक्ट्स के संदर्भ जोड़ने की अनुमति देता है।

  • लाइब्रेरी पैकेज मैनेजर नामक एक विजुअल स्टूडियो एक्सटेंशन वेब से उपयुक्त असेंबली को अपनी परियोजनाओं में खींचने का एक आसान तरीका प्रदान करता है।

  • DbContext API को एंटिटी फ्रेमवर्क के साथ अपनी बातचीत को सरल बनाने के लिए लक्षित किया जाता है।

  • यह उन तरीकों और गुणों की संख्या को भी कम कर देता है जिन्हें आपको आमतौर पर उपयोग किए जाने वाले कार्यों तक पहुंचने की आवश्यकता होती है।

  • एंटिटी फ्रेमवर्क के पिछले संस्करणों में, ये कार्य अक्सर खोज और कोड के लिए जटिल थे।

  • संदर्भ वर्ग रन टाइम के दौरान इकाई ऑब्जेक्ट्स का प्रबंधन करता है, जिसमें डेटाबेस से डेटा के साथ ऑब्जेक्ट्स को पॉप्युलेट करना, ट्रैकिंग बदलना और डेटाबेस को डेटा को बनाए रखना शामिल है।

एक DbContext व्युत्पन्न वर्ग को परिभाषित करना

संदर्भ के साथ काम करने का अनुशंसित तरीका एक वर्ग को परिभाषित करना है जो DbContext से निकलता है और DbSet गुणों को उजागर करता है जो संदर्भ में निर्दिष्ट संस्थाओं के संग्रह का प्रतिनिधित्व करता है। यदि आप EF डिज़ाइनर के साथ काम कर रहे हैं, तो आपके लिए संदर्भ उत्पन्न हो जाएगा। यदि आप पहले कोड के साथ काम कर रहे हैं, तो आप आमतौर पर संदर्भ स्वयं लिखेंगे।

निम्नलिखित कोड एक सरल उदाहरण है जो दिखाता है कि UniContext DbContext से लिया गया है।

  • आप DbSet के साथ स्वचालित गुण का उपयोग कर सकते हैं जैसे गेटटर और सेटर।

  • यह बहुत क्लीनर कोड भी बनाता है, लेकिन जब आपको कोई अन्य तर्क लागू करने का कोई तर्क नहीं है, तो DbSet बनाने के उद्देश्य से इसका उपयोग करने की आवश्यकता नहीं है।

public class UniContext : DbContext {
   public UniContext() : base("UniContext") { }
   public DbSet<Student> Students { get; set; }
   public DbSet<Enrollment> Enrollments { get; set; }
   public DbSet<Course> Courses { get; set; }
}
  • पहले, ईडीएम उन संदर्भ वर्गों को उत्पन्न करता था जो ऑब्जेक्टकोटेक्स्ट क्लास से प्राप्त होते थे।

  • ObjectContext के साथ काम करना थोड़ा जटिल था।

  • DbContext, ObjectContext के चारों ओर एक आवरण है, जो वास्तव में ObjectContext के समान है और सभी विकास मॉडल जैसे Code First, Model First और Database First में उपयोगी और आसान है।

प्रश्नों

आपके द्वारा उपयोग किए जा सकने वाले तीन प्रकार के प्रश्न हैं -

  • एक नई इकाई जोड़ना।
  • किसी मौजूदा इकाई के संपत्ति मूल्यों को बदलना या अपडेट करना।
  • मौजूदा इकाई को हटाना।

नई संस्थाओं को जोड़ना

एंटिटी फ्रेमवर्क के साथ एक नई वस्तु जोड़ना अपनी वस्तु के एक नए उदाहरण का निर्माण करने और इसे DSSet पर ऐड पद्धति का उपयोग करके पंजीकृत करने के रूप में सरल है। निम्न कोड तब होता है जब आप डेटाबेस में एक नया छात्र जोड़ना चाहते हैं।

private static void AddStudent() {

   using (var context = new UniContext()) {

      var student = new Student {
         LastName = "Khan", 
         FirstMidName = "Ali", 
         EnrollmentDate = DateTime.Parse("2005-09-01") 
      };

      context.Students.Add(student); 
      context.SaveChanges();

   }
}

मौजूदा संस्थाओं को बदलना

मौजूदा ऑब्जेक्ट्स को बदलना उतना ही सरल है जितना कि आपके द्वारा दी गई संपत्ति (एस) को दिए गए मूल्य को अपडेट करना और SaveChanges को कॉल करना आसान है। निम्नलिखित कोड में, अली का अंतिम नाम खान से असलम में बदल दिया गया है।

private static void AddStudent() {

   private static void ChangeStudent() {

      using (var context = new UniContext()) {

         var student = (from d in context.Students
            where d.FirstMidName == "Ali" select d).Single();
         student.LastName = "Aslam";
         context.SaveChanges();

      }
   }
}

मौजूदा संस्थाओं को हटाना

एंटिटी फ्रेमवर्क का उपयोग करके एक इकाई को हटाने के लिए, आप DbSet पर निकालें विधि का उपयोग करें। मौजूदा और नए जोड़े गए दोनों संस्थाओं के लिए काम निकालें। निकाले गए निकाय पर कॉल करना जो जोड़ा गया है, लेकिन डेटाबेस में अभी तक सहेजा नहीं गया है, इकाई को जोड़ना रद्द कर देगा। इकाई को परिवर्तन ट्रैकर से हटा दिया जाता है और अब DbContext द्वारा ट्रैक नहीं किया जाता है। परिवर्तन को ट्रैक करने वाली मौजूदा इकाई पर निकालें को कॉल करने से अगली बार SaveChanges नामक विलोपन के लिए इकाई पंजीकृत हो जाएगी। निम्न उदाहरण एक उदाहरण दिखाता है जहां छात्र डेटाबेस से हटा दिया जाता है जिसका पहला नाम अली है।

private static void DeleteStudent() {

   using (var context = new UniContext()) {
      var bay = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
      context.Students.Remove(bay);
      context.SaveChanges();
   }
}

एंटिटी फ्रेमवर्क में, दो प्रकार की संस्थाएं हैं जो डेवलपर्स को डेटा मॉडल के साथ अपने स्वयं के कस्टम डेटा वर्गों का उपयोग करने की अनुमति देती हैं, बिना डेटा कक्षाओं में कोई संशोधन किए बिना।

  • पोक्सो इकाइयाँ
  • गतिशील प्रॉक्सी

पोक्सो एंटिटीज

  • POCO का अर्थ है "सादे-पुराने" सीएलआर ऑब्जेक्ट जो आपके डेटा मॉडल के साथ मौजूदा डोमेन ऑब्जेक्ट के रूप में उपयोग किए जा सकते हैं।

  • POCO डेटा क्लासेस जो संस्थाओं को मैप की जाती हैं, उन्हें डेटा मॉडल में परिभाषित किया जाता है।

  • यह एंटिटी डेटा मॉडल टूल्स द्वारा उत्पन्न किए जाने वाले एंटिटी प्रकारों के समान क्वेरी, इंसर्ट, अपडेट और डिलीट के अधिकांश का भी समर्थन करता है।

  • आप एक वैचारिक मॉडल से दृढ़ता-अज्ञानी इकाई प्रकार उत्पन्न करने के लिए POCO टेम्पलेट का उपयोग कर सकते हैं।

आइए संकल्पना इकाई डेटा मॉडल के निम्नलिखित उदाहरण पर एक नज़र डालें।

उपरोक्त इकाई मॉडल के लिए POCO इकाइयाँ उत्पन्न करने के लिए -

Step 1- डिजाइनर विंडो पर राइट क्लिक करें। यह निम्नलिखित संवाद प्रदर्शित करेगा।

Step 2 - कोड जनरेशन आइटम चुनें ...

Step 3 - EF 6.x DbContext Generator चुनें, नाम लिखें और फिर Add बटन पर क्लिक करें।

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

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

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

namespace ConsoleApplication1 {

   using System;
   using System.Collections.Generic;

   public partial class Student {

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2214:DoNotCallOverridableMethodsInConstructors")]

      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; }

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         CA2227:CollectionPropertiesShouldBeReadOnly")]

      public virtual ICollection<Enrollment> Enrollments { get; set; }

   }
}

एंटिटी मॉडल से कोर्स और एनरोलमेंट टेबल के लिए समान कक्षाएं उत्पन्न की जाती हैं।

गतिशील प्रॉक्सी

पीओसीओ इकाई प्रकारों के उदाहरण बनाते समय, एंटिटी फ्रेमवर्क अक्सर गतिशील रूप से उत्पन्न प्रकार के उदाहरण बनाता है जो इकाई के लिए एक प्रॉक्सी के रूप में कार्य करता है। यह भी कहा जा सकता है कि यह एक रनटाइम प्रॉक्सी क्लास है जैसे कि POCO निकाय का रैपर क्लास।

  • संपत्ति के एक्सेस होने पर आप स्वचालित रूप से क्रिया करने के लिए इकाई के कुछ गुणों को ओवरराइड कर सकते हैं।

  • इस तंत्र का उपयोग रिश्तों के आलसी लोडिंग और स्वचालित परिवर्तन ट्रैकिंग के समर्थन के लिए किया जाता है।

  • यह तकनीक उन मॉडलों पर भी लागू होती है जो कोड फर्स्ट और ईएफ डिजाइनर के साथ बनाई गई हैं।

यदि आप चाहते हैं कि संबंधित वस्तुओं के आलसी लोडिंग का समर्थन करने और POCO वर्गों में परिवर्तन को ट्रैक करने के लिए Entity फ्रेमवर्क, तो POCO वर्गों को निम्नलिखित आवश्यकताओं को पूरा करना चाहिए -

  • कस्टम डेटा वर्ग को सार्वजनिक पहुंच के साथ घोषित किया जाना चाहिए।

  • कस्टम डेटा क्लास को सील नहीं किया जाना चाहिए।

  • कस्टम डेटा क्लास सार नहीं होना चाहिए।

  • कस्टम डेटा क्लास में एक सार्वजनिक या संरक्षित कंस्ट्रक्टर होना चाहिए जिसमें पैरामीटर नहीं हैं।

  • यदि आप POCO इकाई के लिए प्रॉक्सी बनाने के लिए CreateObject विधि का उपयोग करना चाहते हैं, तो मापदंडों के बिना एक संरक्षित कंस्ट्रक्टर का उपयोग करें।

  • CreateObject विधि को कॉल करना प्रॉक्सी के निर्माण की गारंटी नहीं देता है: POCO वर्ग को इस विषय में वर्णित अन्य आवश्यकताओं का पालन करना चाहिए।

  • वर्ग IEntityWithChangeTracker या IEntityWithRelationships इंटरफेस को लागू नहीं कर सकता क्योंकि प्रॉक्सी वर्ग इन इंटरफेस को लागू करते हैं।

  • ProxyCreationEnabled विकल्प को सही पर सेट किया जाना चाहिए।

निम्न उदाहरण गतिशील प्रॉक्सी इकाई वर्ग का है।

public partial class Course {

   public Course() {
      this.Enrollments = new HashSet<Enrollment>();
   }

   public int CourseID { get; set; }
   public string Title { get; set; }
   public int Credits { get; set; }
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

प्रॉक्सी ऑब्जेक्ट्स को अक्षम करने के लिए, ProxyCreationEnabled गुण का मान गलत पर सेट करें।

संबंधपरक डेटाबेस में, संबंध एक ऐसी स्थिति है जो विदेशी कुंजी के माध्यम से संबंधपरक डेटाबेस तालिकाओं के बीच मौजूद है। एक विदेशी कुंजी (FK) स्तंभों का एक संयोजन या संयोजन है जिसका उपयोग दो तालिकाओं में डेटा के बीच एक लिंक को स्थापित करने और लागू करने के लिए किया जाता है। निम्न आरेख में तीन तालिकाएँ हैं।

  • Student
  • Course
  • Enrollment

उपरोक्त आरेख में, आप तालिकाओं के बीच किसी प्रकार का संबंध / संबंध देख सकते हैं। तालिकाओं के बीच तीन प्रकार के संबंध हैं और विभिन्न तालिकाओं के बीच संबंध इस बात पर निर्भर करता है कि संबंधित स्तंभ कैसे परिभाषित किए जाते हैं।

  • एक से कई रिश्ते
  • कई-कई रिश्ते
  • वन-टू-वन रिलेशनशिप

एक से कई रिश्ते

  • एक से कई संबंध सबसे आम प्रकार का रिश्ता है।

  • इस प्रकार के संबंध में, तालिका A की एक पंक्ति में तालिका B में कई मिलान पंक्तियाँ हो सकती हैं, लेकिन तालिका B में एक पंक्ति में तालिका A में केवल एक मिलान पंक्ति हो सकती है।

  • विदेशी कुंजी को तालिका में परिभाषित किया गया है जो रिश्ते के कई अंत का प्रतिनिधित्व करता है।

  • उदाहरण के लिए, ऊपर दिए गए आरेख में छात्र और नामांकन तालिका में एक-टोमनी संबंध है, प्रत्येक छात्र के कई नामांकन हो सकते हैं, लेकिन प्रत्येक नामांकन केवल एक छात्र का है।

इकाई ढांचे में, इन संबंधों को कोड के साथ भी बनाया जा सकता है। निम्नलिखित छात्र और नामांकन कक्षाओं का एक उदाहरण है जो एक से कई संबंधों से जुड़े हैं।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

public class Enrollment {

   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
	
   public Grade? Grade { get; set; }
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }
}

उपरोक्त कोड में, आप देख सकते हैं कि छात्र वर्ग में नामांकन का संग्रह है, लेकिन नामांकन कक्षा में एक ही छात्र वस्तु है।

कई-कई रिश्ते

कई-से-कई संबंधों में, तालिका ए में एक पंक्ति में तालिका बी में कई मिलान पंक्तियाँ हो सकती हैं, और इसके विपरीत।

  • जंक्शन टेबल नामक तीसरी टेबल को परिभाषित करके आप ऐसा रिश्ता बना सकते हैं, जिसकी प्राथमिक कुंजी में टेबल ए और टेबल बी दोनों से विदेशी चाबियां होती हैं।

  • उदाहरण के लिए, छात्र और पाठ्यक्रम की तालिकाओं में कई-से-कई संबंध होते हैं जो इन तालिकाओं में से प्रत्येक से एक से कई संबंधों द्वारा नामांकन तालिका में परिभाषित किया जाता है।

निम्नलिखित कोड में पाठ्यक्रम वर्ग और उपरोक्त दो वर्ग शामिल हैं, अर्थात Student तथा Enrollment

public class Course {
   [DatabaseGenerated(DatabaseGeneratedOption.None)]
	
   public int CourseID { get; set; }
   public string Title { get; set; }
	
   public int Credits { get; set; } 
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

आप देख सकते हैं कि कोर्स क्लास और स्टूडेंट क्लास दोनों में एनरोलमेंट ऑब्जेक्ट्स का संग्रह है जो जंक्शन क्लास एनरोलमेंट के माध्यम से कई-से-कई संबंध बनाता है।

वन-टू-वन रिलेशनशिप

  • एक-से-एक रिश्ते में, तालिका ए में एक पंक्ति में तालिका बी में एक से अधिक मिलान पंक्ति नहीं हो सकती है, और इसके विपरीत।

  • एक-से-एक संबंध बनाया जाता है यदि दोनों संबंधित स्तंभ प्राथमिक कुंजी हैं या अद्वितीय अवरोध हैं।

  • एक-से-एक रिश्ते में, प्राथमिक कुंजी अतिरिक्त रूप से एक विदेशी कुंजी के रूप में कार्य करती है और दोनों तालिका के लिए कोई अलग विदेशी कुंजी स्तंभ नहीं है।

इस प्रकार का संबंध सामान्य नहीं है क्योंकि इस तरह से संबंधित अधिकांश जानकारी एक ही तालिका में होगी। आप एक-से-एक संबंध का उपयोग कर सकते हैं -

  • कई स्तंभों के साथ एक तालिका को विभाजित करें।
  • सुरक्षा कारणों से एक तालिका का अलग भाग।
  • स्टोर डेटा जो अल्पकालिक है और आसानी से तालिका को हटाकर आसानी से हटाया जा सकता है।
  • ऐसी जानकारी संग्रहीत करें जो केवल मुख्य तालिका के सबसेट पर लागू होती है।

निम्नलिखित कोड एक और वर्ग का नाम जोड़ने के लिए है StudentProfile जिसमें छात्र ईमेल आईडी और पासवर्ड होता है।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
   public virtual StudentProfile StudentProfile { get; set; }
}

public class StudentProfile {

   public StudentProfile() {}
   public int ID { get; set; }
   public string Email { get; set; }
   public string Password { get; set; }
	
   public virtual Student Student { get; set; }
}

आप देख सकते हैं कि छात्र इकाई वर्ग में स्टूडेंटप्रोफाइल नेविगेशन प्रॉपर्टी है और स्टूडेंटप्रोफाइल में स्टूडेंट नेविगेशन प्रॉपर्टी है।

प्रत्येक छात्र के पास विश्वविद्यालय डोमेन में प्रवेश करने के लिए केवल एक ईमेल और पासवर्ड है। इन सूचनाओं को छात्र तालिका में जोड़ा जा सकता है लेकिन सुरक्षा कारणों से इसे दूसरी तालिका में अलग कर दिया जाता है।

जीवन काल

एक संदर्भ का जीवनकाल तब शुरू होता है जब उदाहरण बनाया जाता है और समाप्त होता है जब उदाहरण या तो निपटाया जाता है या कचरा एकत्र किया जाता है।

  • जब हम ORM का उपयोग करते हैं तो बनाने के लिए प्रसंग जीवनकाल एक बहुत ही महत्वपूर्ण निर्णय है।

  • संदर्भ एक इकाई कैश की तरह प्रदर्शन कर रहा है, इसलिए इसका मतलब है कि यह सभी भरी हुई संस्थाओं के संदर्भ रखता है जो मेमोरी खपत में बहुत तेजी से बढ़ सकता है और यह मेमोरी लीक का कारण भी बन सकता है।

  • नीचे दिए गए आरेख में, आप एप्लिकेशन से डेटाबेस तक ऊपरी स्तर के डेटा वर्कफ़्लो को कॉन्सेप्ट और इसके विपरीत देख सकते हैं।

इकाई जीवनचक्र

Entity Lifecycle उस प्रक्रिया का वर्णन करती है जिसमें एक इकाई बनाई जाती है, जोड़ी जाती है, संशोधित की जाती है, हटाई जाती है, आदि संस्थाओं के जीवनकाल में कई राज्य होते हैं। इकाई स्थिति को पुनः प्राप्त करने के तरीके को देखने से पहले, आइए देखें कि इकाई स्थिति क्या है। राज्य एक प्रकार की कल्पना हैSystem.Data.EntityState जो निम्नलिखित मूल्यों की घोषणा करता है -

  • Added: इकाई को जोड़ा के रूप में चिह्नित किया गया है।

  • Deleted: निकाय को हटा के रूप में चिह्नित किया गया है।

  • Modified: इकाई को संशोधित किया गया है।

  • Unchanged: इकाई को संशोधित नहीं किया गया है।

  • Detached: इकाई को ट्रैक नहीं किया गया है।

एंटिटी लाइफसाइकल में राज्य परिवर्तन

कभी-कभी संस्थाओं की स्थिति को संदर्भ द्वारा स्वचालित रूप से सेट किया जाता है, लेकिन इसे डेवलपर द्वारा मैन्युअल रूप से संशोधित किया जा सकता है। भले ही एक राज्य से दूसरे राज्य में स्विच के सभी संयोजन संभव हैं, लेकिन उनमें से कुछ अर्थहीन हैं। उदाहरण के लिए,Added के लिए इकाई Deleted राज्य, या इसके विपरीत।

आइए विभिन्न राज्यों के बारे में चर्चा करें।

अपरिवर्तित अवस्था

  • जब कोई इकाई अपरिवर्तित होती है, तो यह संदर्भ के लिए बाध्य होती है, लेकिन इसे संशोधित नहीं किया गया है।

  • डिफ़ॉल्ट रूप से, डेटाबेस से पुनर्प्राप्त एक इकाई इस स्थिति में है।

  • जब कोई इकाई संदर्भ (अटैच विधि के साथ) से जुड़ी होती है, तो यह अपरिवर्तित स्थिति में होती है।

  • संदर्भ उन वस्तुओं में परिवर्तन को ट्रैक नहीं कर सकता है जो इसे संदर्भित नहीं करते हैं, इसलिए जब वे संलग्न होते हैं तो मान लेते हैं कि वे अपरिवर्तित हैं।

अलग किया हुआ राज्य

  • अलग किए गए निकाय की डिफ़ॉल्ट स्थिति अलग है क्योंकि संदर्भ आपके कोड में किसी भी ऑब्जेक्ट के निर्माण को ट्रैक नहीं कर सकता है।

  • यह तब भी सच है जब आप संदर्भ के उपयोग ब्लॉक के अंदर इकाई को तुरंत करते हैं।

  • ट्रैकिंग अक्षम होने पर डेटाबेस से निकाले गए निकाय की स्थिति भी अलग है।

  • जब एक इकाई को अलग किया जाता है, तो यह संदर्भ के लिए बाध्य नहीं होता है, इसलिए इसकी स्थिति को ट्रैक नहीं किया जाता है।

  • इसका निपटान, संशोधित, अन्य वर्गों के साथ संयोजन में उपयोग किया जा सकता है, या आपकी आवश्यकता के किसी अन्य तरीके से उपयोग किया जा सकता है।

  • क्योंकि इस पर नज़र रखने का कोई संदर्भ नहीं है, इसका एंटिटी फ्रेमवर्क से कोई मतलब नहीं है।

जोड़ा गया राज्य

  • जब कोई संस्था एडेड अवस्था में होती है, तो आपके पास कुछ विकल्प होते हैं। वास्तव में, आप इसे केवल संदर्भ से अलग कर सकते हैं।

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

  • यह एक नई इकाई है और डेटाबेस में एक पंक्ति के साथ कोई पत्राचार नहीं है।

  • यह उन राज्यों में से एक में होने के लिए एक मौलिक शर्त है (लेकिन यह नियम संदर्भ द्वारा लागू नहीं किया गया है)।

संशोधित राज्य

  • जब एक इकाई को संशोधित किया जाता है, तो इसका मतलब है कि यह अपरिवर्तित स्थिति में था और फिर कुछ संपत्ति बदल दी गई थी।

  • एक इकाई संशोधित स्थिति में प्रवेश करने के बाद, यह अलग या हटाए गए स्थिति में जा सकती है, लेकिन यह अपरिवर्तित स्थिति में वापस रोल नहीं कर सकता है, भले ही आप मूल मानों को मैन्युअल रूप से पुनर्स्थापित करें।

  • इसे भी जोड़ा नहीं जा सकता है, जब तक कि आप इकाई को अलग नहीं करते हैं और संदर्भ में जोड़ नहीं देते हैं, क्योंकि इस आईडी के साथ एक पंक्ति पहले से ही डेटाबेस में मौजूद है, और इसे जारी रखने पर आपको एक रनटाइम अपवाद मिलेगा।

हटाए गए राज्य

  • एक इकाई हटाए गए राज्य में प्रवेश करती है क्योंकि यह अपरिवर्तित या संशोधित थी और फिर DeleteObject विधि का उपयोग किया गया था।

  • यह सबसे अधिक प्रतिबंधात्मक स्थिति है, क्योंकि यह इस राज्य से किसी भी अन्य मूल्य में बदल रहा है, लेकिन अलग है।

usingबयान यदि आप सभी संसाधनों को चाहते हैं कि संदर्भ को ब्लॉक के अंत में निपटाया जाए। जब आप उपयोग करते हैंusing बयान, फिर संकलक स्वचालित रूप से एक कोशिश / अंत में ब्लॉक बनाता है और अंत में ब्लॉक में कॉल कॉल करता है।

using (var context = new UniContext()) {

   var student = new Student {
      LastName = "Khan", 
      FirstMidName = "Ali", 
      EnrollmentDate = DateTime.Parse("2005-09-01")
   };

   context.Students.Add(student);
   context.SaveChanges();
}

लंबे समय तक चलने वाले संदर्भ के साथ काम करते समय निम्नलिखित पर विचार करें -

  • जब आप अधिक वस्तुओं और उनके संदर्भों को मेमोरी में लोड करते हैं, तो संदर्भ की मेमोरी खपत तेजी से बढ़ सकती है। यह प्रदर्शन समस्याओं का कारण हो सकता है।

  • संदर्भ का निपटान करने के लिए याद रखें जब इसकी आवश्यकता नहीं है।

  • यदि अपवाद अपवाद के कारण अपरिवर्तनीय स्थिति में है, तो संपूर्ण अनुप्रयोग समाप्त हो सकता है।

  • समसामयिक-संबंधित मुद्दों में चलने की संभावना उस समय के बीच की खाई में बढ़ जाती है, जब डेटा की पुष्टि होती है और अद्यतन बढ़ता है।

  • वेब एप्लिकेशन के साथ काम करते समय, अनुरोध के अनुसार संदर्भ उदाहरण का उपयोग करें।

  • विंडोज प्रेजेंटेशन फाउंडेशन (WPF) या विंडोज फॉर्म के साथ काम करते समय, प्रति प्रपत्र संदर्भ उदाहरण का उपयोग करें। यह आपको संदर्भ प्रदान करने वाली परिवर्तन-ट्रैकिंग कार्यक्षमता का उपयोग करने देता है।

अंगूठे का नियम

Web Applications

  • यह अब एक सामान्य और सबसे अच्छा अभ्यास है कि वेब अनुप्रयोगों के लिए, संदर्भ प्रति अनुरोध का उपयोग किया जाता है।

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

Desktop Applications

  • डेस्कटॉप एप्लिकेशन के लिए, जैसे कि Win Forms / WPF, इत्यादि संदर्भ प्रति प्रपत्र / संवाद / पृष्ठ का उपयोग किया जाता है।

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

  • इस तरह, हम संदर्भ की क्षमताओं का एक बहुत हासिल करेंगे और लंबे समय तक चलने वाले संदर्भों के निहितार्थ से ग्रस्त नहीं होंगे।

एंटिटी फ्रेमवर्क एक इकाई मॉडल बनाने के लिए तीन दृष्टिकोण प्रदान करता है और हर एक के अपने पेशेवरों और विपक्ष हैं।

  • कोड प्रथम
  • डेटाबेस पहले
  • मॉडल प्रथम

इस अध्याय में, हम कोड पहले दृष्टिकोण का संक्षेप में वर्णन करेंगे। कुछ डेवलपर्स कोड में डिजाइनर के साथ काम करना पसंद करते हैं, जबकि अन्य केवल अपने कोड के साथ काम करना पसंद करेंगे। उन डेवलपर्स के लिए, एंटिटी फ्रेमवर्क में एक मॉडलिंग वर्कफ़्लो है जिसे कोड फ़र्स्ट कहा जाता है।

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

  • यह भी इस्तेमाल किया जा सकता है यदि आपके पास एक खाली डेटाबेस है और फिर कोड फर्स्ट में नई तालिकाएँ भी शामिल होंगी

  • कोड पहले आपको C # या VB.Net कक्षाओं का उपयोग करके अपने मॉडल को परिभाषित करने की अनुमति देता है।

  • अतिरिक्त कॉन्फ़िगरेशन वैकल्पिक रूप से आपकी कक्षाओं और संपत्तियों पर विशेषताओं का उपयोग करके या धाराप्रवाह एपीआई का उपयोग करके किया जा सकता है।

कोड पहले क्यों?

  • कोड फर्स्ट वास्तव में पहेली टुकड़ों के समूह से बना है। पहले आपकी डोमेन कक्षाएं हैं।

  • डोमेन कक्षाओं का एंटिटी फ्रेमवर्क से कोई लेना-देना नहीं है। वे आपके व्यवसाय डोमेन के आइटम हैं।

  • एंटिटी फ्रेमवर्क, का एक संदर्भ है, जो उन वर्गों और आपके डेटाबेस के बीच बातचीत का प्रबंधन करता है।

  • संदर्भ कोड प्रथम के लिए विशिष्ट नहीं है। यह एक एंटिटी फ्रेमवर्क फीचर है।

  • कोड फर्स्ट एक मॉडल बिल्डर को जोड़ता है जो आपकी कक्षाओं का निरीक्षण करता है कि संदर्भ प्रबंध कर रहा है, और फिर यह निर्धारित करने के लिए नियमों या सम्मेलनों का एक सेट का उपयोग करता है कि कैसे उन वर्गों और रिश्तों का एक मॉडल वर्णन करता है, और उस मॉडल को आपके डेटाबेस में कैसे मैप करना चाहिए।

  • यह सब रनटाइम पर होता है। आप इस मॉडल को कभी नहीं देख पाएंगे, यह सिर्फ स्मृति में है।

  • यदि आवश्यक हो तो कोड प्रथम में उस मॉडल का उपयोग करने की क्षमता है।

  • कोड फर्स्ट माइग्रेशन नामक सुविधा का उपयोग करके, यदि मॉडल बदलता है तो यह डेटाबेस को अपडेट भी कर सकता है।

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

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

  • मॉडल को 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...

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

इस अध्याय में, डेटाबेस फर्स्ट एप्रोच के साथ एक इकाई डेटा मॉडल बनाने के बारे में जानें।

  • डाटाबेस फर्स्ट एप्रोच डाटा डेटा मॉडल के लिए कोड फर्स्ट एंड मॉडल फर्स्ट एप्रोच का विकल्प प्रदान करता है। यह परियोजना में डेटाबेस से मॉडल कोड (कक्षाएं, गुण, DbContext आदि) बनाता है और वे कक्षाएं डेटाबेस और नियंत्रक के बीच की कड़ी बन जाती हैं।

  • डेटाबेस फर्स्ट एप्रोच मौजूदा डेटाबेस से एंटिटी फ्रेमवर्क बनाता है। हम अन्य सभी कार्यात्मकताओं का उपयोग करते हैं, जैसे कि मॉडल / डेटाबेस सिंक और कोड पीढ़ी, उसी तरह हमने मॉडल पहले दृष्टिकोण में उनका उपयोग किया था।

एक सरल उदाहरण लेते हैं। हमारे पास पहले से ही एक डेटाबेस है जिसमें 3 टेबल हैं जैसा कि निम्नलिखित छवि में दिखाया गया है।

Step 1 - DatabaseFirstDemo नाम के साथ एक नया कंसोल प्रोजेक्ट बनाते हैं।

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

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

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

Step 5 - डेटाबेस से EF डिज़ाइनर चुनें और नेक्स्ट बटन पर क्लिक करें।

Step 6 - मौजूदा डेटाबेस का चयन करें और नेक्स्ट पर क्लिक करें।

Step 7 - एंटिटी फ्रेमवर्क 6.x चुनें और नेक्स्ट पर क्लिक करें।

Step 8 - सभी तालिकाओं का चयन करें दृश्य और संग्रहीत प्रक्रिया जिसे आप शामिल करना चाहते हैं और समाप्त पर क्लिक करें।

आप देखेंगे कि डेटाबेस से एंटिटी मॉडल और POCO कक्षाएं उत्पन्न होती हैं।

अब हम program.cs फ़ाइल में निम्नलिखित कोड लिखकर डेटाबेस से सभी छात्रों को पुनः प्राप्त करते हैं।

using System;
using System.Linq;

namespace DatabaseFirstDemo {

   class Program {

      static void Main(string[] args) {

         using (var db = new UniContextEntities()) {

            var query = from b in db.Students
               orderby b.FirstMidName select b;

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

            foreach (var item in query) {
               Console.WriteLine(item.FirstMidName +" "+ item.LastName);
            }

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

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

All student in the database:
Ali Khan
Arturo   finand
Bill Gates
Carson Alexander
Gytis Barzdukas
Laura Norman
Meredith Alonso
Nino Olivetto
Peggy Justice
Yan Li
Press any key to exit...

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

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

इस अध्याय में, हम डिज़ाइनर या डेटाबेस फर्स्ट के साथ मॉडल बनाने या कोड फर्स्ट का उपयोग करने पर ध्यान केंद्रित करते हैं। निम्नलिखित कुछ दिशानिर्देश हैं जो आपको यह तय करने में मदद करेंगे कि कौन से मॉडलिंग वर्कफ़्लो को चुनना है।

  • हमने पहले कोड कोड मॉडलिंग, डेटाबेस फर्स्ट मॉडलिंग और एक मॉडल फर्स्ट मॉडलिंग वर्कफ़्लो का उदाहरण देखा है।

  • डेटाबेस फर्स्ट और मॉडल फर्स्ट वर्कफ़्लोज़ ने डिज़ाइनर का उपयोग किया लेकिन एक डेटाबेस के साथ एक मॉडल बनाने के लिए शुरू होता है और दूसरा डेटाबेस बनाने के लिए मॉडल पर शुरू होता है।

  • उन डेवलपर्स के लिए जो विज़ुअल डिज़ाइनर प्लस कोड पीढ़ी का उपयोग नहीं करना चाहते हैं, एंटिटी फ्रेमवर्क में कोड फ़र्स्ट नामक एक पूरी तरह से अलग वर्कफ़्लो है।

  • कोड फ़र्स्ट के लिए विशिष्ट वर्कफ़्लो ब्रांड नए अनुप्रयोगों के लिए बहुत अच्छा है जहाँ आपके पास डेटाबेस भी नहीं है। आप अपनी कक्षाओं और कोड को परिभाषित करते हैं और फिर कोड को पहले बता देते हैं कि आपके डेटाबेस को कैसा दिखना चाहिए।

  • कोड फर्स्ट को डेटाबेस से शुरू करना भी संभव है और इससे कोड फर्स्ट थोड़ा विरोधाभास बन जाता है। लेकिन आपको एक इंजीनियर को कक्षाओं में एक डेटाबेस को रिवर्स करने देने का एक उपकरण है जो कोडिंग पर एक सिर शुरू करने का एक शानदार तरीका है।

इन विकल्पों को देखते हुए, निर्णय वृक्ष को देखें।

  • यदि आप जेनरेट किए गए कोड में विज़ुअल डिज़ाइनर के साथ काम करना पसंद करते हैं, तो आप एक वर्कफ़्लोज़ चुनना चाहेंगे जिसमें EF डिज़ाइनर शामिल हो। यदि आपका डेटाबेस पहले से मौजूद है, तो डेटाबेस फर्स्ट आपका रास्ता है।

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

  • यदि आप केवल कोड के साथ काम करना चाहते हैं, न कि डिजाइनर के रूप में, तो कोड फर्स्ट संभवतः आपके लिए उस टूल का उपयोग करने के विकल्प के साथ है जो डेटाबेस को कक्षाओं में रिवर्स करता है।

  • यदि आपके पास मौजूदा कक्षाएं हैं, तो आपका सबसे अच्छा दांव कोड फर्स्ट के साथ उनका उपयोग करना है।

पिछले अध्यायों में, आपने इकाई डेटा मॉडल को परिभाषित करने के तीन अलग-अलग तरीके सीखे।

  • उनमें से दो, डेटाबेस फर्स्ट और मॉडल फर्स्ट, कोड पीढ़ी के साथ संयुक्त इकाई फ्रेमवर्क डिजाइनर पर निर्भर थे।

  • तीसरा, कोड फर्स्ट, आपको एक विज़ुअल डिज़ाइनर को छोड़ देता है और सिर्फ अपना कोड लिखता है।

  • आप चाहे जो भी रास्ता चुनें, आप डोमेन कक्षाओं के साथ समाप्त हो जाएंगे और एक या अधिक एंटिटी फ्रेमवर्क DbContext कक्षाएं आपको उन वर्गों के लिए प्रासंगिक डेटा को पुनः प्राप्त करने और बनाए रखने की अनुमति देती हैं।

आपके अनुप्रयोगों में DbContext API का उपयोग आपकी कक्षाओं और आपके डेटाबेस के बीच एक सेतु के रूप में किया जाता है। DbContext इकाई संरचना में सबसे महत्वपूर्ण वर्गों में से एक है।

  • यह प्रश्नों को व्यक्त और निष्पादित करने में सक्षम बनाता है।

  • यह डेटाबेस से क्वेरी परिणाम लेता है और उन्हें हमारे मॉडल कक्षाओं के उदाहरणों में बदल देता है।

  • यह जोड़ने और हटाने सहित संस्थाओं में परिवर्तन का ट्रैक रख सकता है, और फिर मांग पर डेटाबेस को भेजे गए बयानों को सम्मिलित करने, अपडेट और हटाने के निर्माण को ट्रिगर करता है।

निम्नलिखित डोमेन विज्ञापन संदर्भ कक्षाएं हैं, जिनके आधार पर हम इस अध्याय में विभिन्न ऑपरेशन करेंगे। यह वही उदाहरण है जो हमने chapater, डेटाबेस फर्स्ट एप्रोच में बनाया है।

प्रसंग वर्ग कार्यान्वयन

using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Data.Entity.Core.Objects;
using System.Linq;

namespace DatabaseFirstDemo {

   public partial class UniContextEntities : DbContext {

      public UniContextEntities(): base("name = UniContextEntities") {}

      protected override void OnModelCreating(DbModelBuilder modelBuilder) {
         throw new UnintentionalCodeFirstException();
      }

      public virtual DbSet<Course> Courses { get; set; }
      public virtual DbSet<Enrollment> Enrollments { get; set; }
      public virtual DbSet<Student> Students { get; set; }
   }
}

डोमेन कक्षाएं कार्यान्वयन

कोर्स की क्लास

namespace DatabaseFirstDemo {

   using System;
   using System.Collections.Generic;
	
   public partial class Course {

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2214:DoNotCallOverridableMethodsInConstructors")]

      public Course() {
         this.Enrollments = new HashSet<Enrollment>();
      }
	
      public int CourseID { get; set; }
      public string Title { get; set; }
      public int Credits { get; set; }
	
      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2227:CollectionPropertiesShouldBeReadOnly")]
			
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }
}

छात्र वर्ग

namespace DatabaseFirstDemo {

   using System;
   using System.Collections.Generic; 

   public partial class Student {

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2214:DoNotCallOverridableMethodsInConstructors")]

      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; }

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2227:CollectionPropertiesShouldBeReadOnly")]
			
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }
}

नामांकन वर्ग

namespace DatabaseFirstDemo {

   using System;
   using System.Collections.Generic; 

   public partial class Enrollment {

      public int EnrollmentID { get; set; }
      public int CourseID { get; set; }
      public int StudentID { get; set; }
      public Nullable<int> Grade { get; set; }
		
      public virtual Course Course { get; set; }
      public virtual Student Student { get; set; }
   }
}

ऑपरेशन बनाएँ

एंटिटी फ्रेमवर्क के साथ एक नई वस्तु जोड़ना अपनी वस्तु के एक नए उदाहरण का निर्माण करने और इसे DSSet पर ऐड पद्धति का उपयोग करके पंजीकृत करने के रूप में सरल है। निम्न कोड आपको डेटाबेस में एक नया छात्र जोड़ने की सुविधा देता है।

class Program {

   static void Main(string[] args) {

      var newStudent = new Student();

      //set student name

      newStudent.FirstMidName = "Bill";
      newStudent.LastName = "Gates";
      newStudent.EnrollmentDate = DateTime.Parse("2015-10-21");
      newStudent.ID = 100;

      //create DBContext object

      using (var dbCtx = new UniContextEntities()) {

         //Add Student object into Students DBset
         dbCtx.Students.Add(newStudent);

         // call SaveChanges method to save student into database
         dbCtx.SaveChanges();
      }
   }
}

अद्यतन अद्यतन करें

मौजूदा ऑब्जेक्ट्स को बदलना उतना ही सरल है जितना कि आपके द्वारा दी गई संपत्ति (एस) को दिए गए मूल्य को अपडेट करना और SaveChanges को कॉल करना आसान है। उदाहरण के लिए, अली से अंतिम नाम को खान से असलम में बदलने के लिए निम्न कोड का उपयोग किया जाता है।

using (var context = new UniContextEntities()) {

   var student = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
   student.LastName = "Aslam";
   context.SaveChanges();
}

ऑपरेशन हटाएँ

एंटिटी फ्रेमवर्क का उपयोग करके एक इकाई को हटाने के लिए, आप DbSet पर निकालें विधि का उपयोग करें। मौजूदा और नए जोड़े गए दोनों संस्थाओं के लिए काम निकालें। निकाले गए निकाय पर कॉल करना जो जोड़ा गया है, लेकिन डेटाबेस में अभी तक सहेजा नहीं गया है, इकाई को जोड़ना रद्द कर देगा। इकाई को परिवर्तन ट्रैकर से हटा दिया जाता है और अब DbContext द्वारा ट्रैक नहीं किया जाता है। परिवर्तन को ट्रैक करने वाली मौजूदा इकाई पर निकालें को कॉल करने से अगली बार SaveChanges नामक विलोपन के लिए इकाई पंजीकृत हो जाएगी। निम्न उदाहरण एक कोड का है जहां छात्र डेटाबेस से हटा दिया जाता है जिसका पहला नाम अली है।

using (var context = new UniContextEntities()) {
   var bay = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
   context.Students.Remove(bay);
   context.SaveChanges();
}

ऑपरेशन पढ़ें

डेटाबेस से मौजूदा डेटा को पढ़ना बहुत सरल है। निम्नलिखित कोड है जिसमें छात्र तालिका के सभी डेटा को पुनर्प्राप्त किया जाता है और फिर छात्रों के पहले और अंतिम नाम के साथ वर्णमाला क्रम में एक कार्यक्रम प्रदर्शित किया जाएगा।

using (var db = new UniContextEntities()) {

   var query = from b in db.Students orderby b.FirstMidName select b;
   Console.WriteLine("All All student in the database:");

   foreach (var item in query) {
      Console.WriteLine(item.FirstMidName +" "+ item.LastName);
   }

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

किसी भी डेटा ऐक्सेस डेवलपर को डेटा कंसीडर से संबंधित प्रश्न का उत्तर देते समय कठिनाई का सामना करना पड़ता है, "एक ही समय में एक से अधिक व्यक्ति एक ही डेटा को एडिट करने से क्या होता है?"

  • हमारे बीच और अधिक भाग्यशाली व्यापारिक नियमों से निपटते हैं जो कहते हैं कि "कोई समस्या नहीं है, जीत में आखिरी है।"

  • इस मामले में, संगामिति एक मुद्दा नहीं है। अधिक संभावना है, यह उतना सरल नहीं है, और एक बार में प्रत्येक परिदृश्य को हल करने के लिए चांदी की गोली नहीं है।

  • डिफ़ॉल्ट रूप से, एंटिटी फ्रेमवर्क "जीत में अंतिम एक" का अर्थ लेगा, जिसका अर्थ है कि नवीनतम अपडेट लागू किया जाता है, भले ही किसी और ने समय डेटा को पुनर्प्राप्त करने के बीच डेटा अपडेट किया हो और समय डेटा सहेजा गया हो।

आइए इसे बेहतर ढंग से समझने के लिए एक उदाहरण लेते हैं। निम्न उदाहरण पाठ्यक्रम तालिका में एक नया कॉलम वर्जननो जोड़ता है।

डिजाइनर पर जाएं और डिजाइनर विंडो पर राइट-क्लिक करें और डेटाबेस से अपडेट मॉडल का चयन करें ...

आप देखेंगे कि कोर्स एंटिटी में एक और कॉलम जोड़ा गया है।

नए बनाए गए संस्करण VersionNo पर राइट-क्लिक करें और गुण का चयन करें और निम्नलिखित छवि में दिखाए गए अनुसार ConcurrencyMode को फिक्स्ड में बदलें।

किसी भी समय एक पाठ्यक्रम अद्यतन किया जाता है, किसी भी समय एक पाठ्यक्रम को अद्यतन किया जाता है, के लिए पाठ्यक्रम के। के साथ सेट करें, अद्यतन कमांड अपने EntityKey और उसके VersionNo संपत्ति का उपयोग कर पाठ्यक्रम के लिए दिखेगा।

आइए एक साधारण परिदृश्य पर नज़र डालें। दो उपयोगकर्ता एक ही समय में एक ही कोर्स को प्राप्त करते हैं और उपयोगकर्ता 1 मैथ्स के लिए उस पाठ्यक्रम का शीर्षक बदल देता है और उपयोगकर्ता से पहले परिवर्तन बचाता है। बाद में जब उपयोगकर्ता 2 उस पाठ्यक्रम का शीर्षक बदलता है जिसे उपयोगकर्ता 1 से पहले पुनर्प्राप्त किया गया था, तो अपने परिवर्तनों को सहेजें, इसमें केस उपयोगकर्ता 2 को समवर्ती अपवाद मिलेगा"User2: Optimistic Concurrency exception occured"

using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Linq;

namespace DatabaseFirstDemo {

   class Program {

      static void Main(string[] args) {

         Course c1 = null;
         Course c2 = null;

         //User 1 gets Course

         using (var context = new UniContextEntities()) {
            context.Configuration.ProxyCreationEnabled = false;
            c1 = context.Courses.Where(s ⇒ s.CourseID == 1).Single();
         }

         //User 2 also get the same Course

         using (var context = new UniContextEntities()) {
            context.Configuration.ProxyCreationEnabled = false;
            c2 = context.Courses.Where(s ⇒ s.CourseID == 1).Single();
         }

         //User 1 updates Course Title
         c1.Title = "Edited from user1";

         //User 2 updates Course Title
         c2.Title = "Edited from user2";

         //User 1 saves changes first

         using (var context = new UniContextEntities()) {

            try {
               context.Entry(c1).State = EntityState.Modified;
               context.SaveChanges();
            } catch (DbUpdateConcurrencyException ex) {
               Console.WriteLine("User1: Optimistic Concurrency exception occurred");
            }
         }

         //User 2 saves changes after User 1.
         //User 2 will get concurrency exection
         //because CreateOrModifiedDate is different in the database

         using (var context = new UniContextEntities()) {

            try {
               context.Entry(c2).State = EntityState.Modified;
               context.SaveChanges();
            } catch (DbUpdateConcurrencyException ex) {
               Console.WriteLine("User2: Optimistic Concurrency exception occurred");
            }
         }
      }
   }
}

एंटिटी फ्रेमवर्क के सभी संस्करणों में, जब भी आप निष्पादित करते हैं SaveChanges()डेटाबेस को सम्मिलित करने, अपडेट करने या हटाने के लिए, फ्रेमवर्क उस ऑपरेशन को लेनदेन में लपेट देगा। जब आप SaveChanges का आह्वान करते हैं, तो संदर्भ स्वचालित रूप से एक लेन-देन शुरू करता है और दृढ़ता या सफल होने के आधार पर इसे वापस करता है या रोल करता है।

  • यह सब आपके लिए पारदर्शी है, और आपको इससे निपटने की कभी आवश्यकता नहीं होगी।

  • यह लेन-देन ऑपरेशन को निष्पादित करने के लिए केवल लंबे समय तक रहता है और फिर पूरा होता है।

  • जब आप ऐसे किसी अन्य ऑपरेशन को निष्पादित करते हैं, तो एक नया लेनदेन शुरू होता है।

इकाई फ्रेमवर्क 6 निम्नलिखित प्रदान करता है -

Database.BeginTransaction ()

  • यह उपयोगकर्ताओं के लिए लेनदेन शुरू करने और पूरा करने के लिए एक मौजूदा DbContext के भीतर एक सरल और आसान तरीका है।

  • यह एक ही लेन-देन के भीतर कई ऑपरेशनों को संयोजित करने की अनुमति देता है और इसलिए या तो सभी प्रतिबद्ध हैं या सभी को एक के रूप में वापस रोल किया गया है।

  • यह उपयोगकर्ता को लेनदेन के लिए अलगाव स्तर को अधिक आसानी से निर्दिष्ट करने की अनुमति देता है।

Database.UseTransaction ()

  • यह DbContext को एक लेनदेन का उपयोग करने की अनुमति देता है, जिसे इकाई ढांचे के बाहर शुरू किया गया था।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जहां एक ही लेनदेन में कई ऑपरेशन किए जाते हैं। कोड इस प्रकार है -

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         using (var dbContextTransaction = context.Database.BeginTransaction()) {

            try {

               Student student = new Student() {
                  ID = 200, 
                  FirstMidName = "Ali", 
                  LastName = "Khan", 
                  EnrollmentDate = DateTime.Parse("2015-12-1")
               };

               context.Students.Add(student);

               context.Database.ExecuteSqlCommand(@"UPDATE Course SET Title = 
                  'Calculus'" + "WHERE CourseID = 1045");

               var query = context.Courses.Where(c ⇒ c.CourseID == 1045);

               foreach (var item in query) {
                  Console.WriteLine(item.CourseID.ToString()
                     + " " + item.Title + " " + item.Credits);
               }

               context.SaveChanges();
               var query1 = context.Students.Where(s ⇒ s.ID == 200);

               foreach (var item in query1) {
                  Console.WriteLine(item.ID.ToString() 
                     + " " + item.FirstMidName + " " + item.LastName);
               }

               dbContextTransaction.Commit();
            } catch (Exception) {
               dbContextTransaction.Rollback();
            }

         }
      }
   }
}
  • लेनदेन की शुरुआत के लिए आवश्यक है कि अंतर्निहित स्टोर कनेक्शन खुला हो।

  • इसलिए Database.BeginTransaction () कॉल करने पर कनेक्शन खुल जाएगा, अगर यह पहले से ही नहीं खुला है।

  • यदि DbContextTransaction ने कनेक्शन खोला है, तो यह डिस्पोज़ () कहे जाने पर इसे बंद कर देगा।

एक दृश्य एक ऑब्जेक्ट है जिसमें पूर्वनिर्धारित क्वेरी द्वारा प्राप्त डेटा होता है। एक दृश्य एक आभासी वस्तु या तालिका है जिसका परिणाम सेट क्वेरी से लिया गया है। यह एक वास्तविक तालिका के समान है क्योंकि इसमें डेटा के कॉलम और पंक्तियाँ हैं। निम्नलिखित विचारों के कुछ विशिष्ट उपयोग हैं -

  • अंतर्निहित तालिकाओं का डेटा फ़िल्टर करें
  • सुरक्षा उद्देश्यों के लिए डेटा फ़िल्टर करें
  • कई सर्वरों में वितरित डेटा को केंद्रीकृत करें
  • डेटा का पुन: प्रयोज्य सेट बनाएँ

दृश्य का उपयोग उसी तरह से किया जा सकता है जैसे आप तालिकाओं का उपयोग कर सकते हैं। एक इकाई के रूप में दृश्य का उपयोग करने के लिए, पहले आपको ईडीएम में डेटाबेस दृश्य जोड़ना होगा। अपने मॉडल में विचार जोड़ने के बाद फिर आप इसके साथ उसी तरह काम कर सकते हैं जैसे क्रिएट, अपडेट और डिलीट ऑपरेशंस को छोड़कर सामान्य इकाइयाँ।

आइए एक नज़र डालते हैं, डेटाबेस से मॉडल में विचारों को कैसे जोड़ा जाए।

Step 1 - एक नया कंसोल एप्लिकेशन प्रोजेक्ट बनाएं।

Step 2 - समाधान एक्सप्लोरर में प्रोजेक्ट पर राइट-क्लिक करें और Add → New Item चुनें।

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

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

Step 5 - डेटाबेस से EF डिज़ाइनर चुनें और नेक्स्ट बटन पर क्लिक करें।

Step 6 - मौजूदा डेटाबेस का चयन करें और नेक्स्ट पर क्लिक करें।

Step 7 - एंटिटी फ्रेमवर्क 6.x चुनें और नेक्स्ट पर क्लिक करें।

Step 8 - अपने डेटाबेस से तालिकाओं और विचारों का चयन करें और समाप्त पर क्लिक करें।

आप डिजाइनर विंडो में देख सकते हैं कि एक दृश्य बनाया गया है और आप इसे एक इकाई के रूप में कार्यक्रम में उपयोग कर सकते हैं।

समाधान एक्सप्लोरर में, आप देख सकते हैं कि MyView वर्ग भी डेटाबेस से उत्पन्न होता है।

आइए एक उदाहरण लेते हैं जिसमें सभी डेटा दृश्य से पुनर्प्राप्त किए जाते हैं। निम्नलिखित कोड है -

class Program {

   static void Main(string[] args) {

      using (var db = new UniContextEntities()) {

         var query = from b in db.MyViews
            orderby b.FirstMidName select b;

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

         foreach (var item in query) {
            Console.WriteLine(item.FirstMidName + " " + item.LastName);
         }

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

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

All student in the database:
Ali Khan
Arturo   finand
Bill Gates
Carson Alexander
Gytis Barzdukas
Laura Norman
Meredith Alonso
Nino Olivetto
Peggy Justice
Yan Li
Press any key to exit...

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

एक सूचकांक एक डिस्क-डिस्क डेटा संरचना है जो तालिकाओं और विचारों पर आधारित है। सूचकांक ज्यादातर मामलों में डेटा की पुनर्प्राप्ति को तेज और कुशल बनाते हैं। हालाँकि, अनुक्रमणिका के साथ किसी तालिका या दृश्य को ओवरलोड करने से अन्य ऑपरेशन जैसे आवेषण या अपडेट के प्रदर्शन को अप्रिय रूप से प्रभावित किया जा सकता है।

  • अनुक्रमण इकाई संरचना में नई सुविधा है जहां आप डेटाबेस से डेटा क्वेरी करने के लिए आवश्यक समय को कम करके अपने कोड पहले आवेदन के प्रदर्शन में सुधार कर सकते हैं।

  • आप का उपयोग कर अपने डेटाबेस में अनुक्रमित जोड़ सकते हैं Index विशेषता, और डिफ़ॉल्ट को ओवरराइड करें Unique तथा Clustered सूचकांक को आपके परिदृश्य के अनुकूल बनाने के लिए सेटिंग्स।

आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें कोर्सआईडी को कोर्स क्लास में शामिल किया गया है।

public partial class Course {

   public Course() {
      this.Enrollments = new HashSet<Enrollment>();
   }

   [Index]
   public int CourseID { get; set; }
   public string Title { get; set; }
	
   public int Credits { get; set; }
   public byte[] VersionNo { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

ऊपर बनाई गई कुंजी गैर-अद्वितीय, गैर-संकुल है। इन चूक को ओवरराइड करने के लिए ओवरलोड उपलब्ध हैं -

  • इंडेक्स को एक क्लस्टर इंडेक्स बनाने के लिए, आपको IsClustered = true निर्दिष्ट करना होगा

  • इसी तरह, आप IsUnique = true को निर्दिष्ट करके एक सूचकांक को एक अद्वितीय सूचकांक भी बना सकते हैं

आइए निम्नलिखित सी # कोड पर एक नज़र डालें जहां एक सूचकांक को क्लस्टर किया जाता है और अद्वितीय होता है।

public partial class Course {

   public Course() {
      this.Enrollments = new HashSet<Enrollment>();
   }

   [Index(IsClustered = true, IsUnique = true)]
   public int CourseID { get; set; }
   public string Title { get; set; }
	
   public int Credits { get; set; }
   public byte[] VersionNo { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

सूचकांक विशेषता का उपयोग डेटाबेस में एक अद्वितीय सूचकांक बनाने के लिए किया जा सकता है। हालांकि, इसका मतलब यह नहीं है कि रिश्तों के साथ काम करते समय ईएफ कॉलम की विशिष्टता के बारे में तर्क करने में सक्षम होगा, आदि इस सुविधा को आमतौर पर "अद्वितीय बाधाओं" के समर्थन के रूप में संदर्भित किया जाता है।

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

  • आप डेटाबेस तालिकाओं पर पूर्वनिर्धारित तर्क करने के लिए संग्रहीत कार्यविधियों का उपयोग कर सकते हैं, और कई संगठनों के पास ऐसी नीतियां हैं जो इन संग्रहीत प्रक्रियाओं के उपयोग की आवश्यकता होती हैं।

  • यह भी निर्दिष्ट कर सकता है कि ईएफ को संस्थाओं को सम्मिलित करने, अपडेट करने या हटाने के लिए अपनी संग्रहीत प्रक्रियाओं का उपयोग करना चाहिए।

  • यद्यपि गतिशील रूप से निर्मित कमांड सुरक्षित, कुशल हैं, और आम तौर पर उन लोगों से बेहतर या बेहतर हैं जो आप स्वयं लिख सकते हैं, ऐसे कई मामले हैं जहां संग्रहीत प्रक्रियाएं पहले से मौजूद हैं और आपकी कंपनी की कार्यप्रणालियों में तालिकाओं के प्रत्यक्ष उपयोग को प्रतिबंधित किया जा सकता है।

  • वैकल्पिक रूप से, आप केवल स्टोर पर निष्पादित की गई चीजों पर स्पष्ट नियंत्रण रखना चाहते हैं और संग्रहीत कार्यविधियाँ बनाना पसंद कर सकते हैं।

निम्न उदाहरण फ़ाइल → नई → प्रोजेक्ट से एक नई परियोजना बनाता है।

Step 1 - मध्य फलक से कंसोल एप्लिकेशन का चयन करें और नाम फ़ील्ड में StoredProceduresDemo दर्ज करें।

Step 2 - सर्वर एक्सप्लोरर में अपने डेटाबेस पर राइट-क्लिक करें।

Step 3 - नई क्वेरी का चयन करें और अपने डेटाबेस में एक नई तालिका जोड़ने के लिए T-SQL संपादक में निम्न कोड दर्ज करें।

IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = 
   OBJECT_ID(N'[dbo].[StudentGrade]') AND type in (N'U'))

BEGIN

   CREATE TABLE [dbo].[StudentGrade](

      [EnrollmentID] [int] IDENTITY(1,1) NOT NULL,
      [CourseID] [int] NOT NULL,
      [StudentID] [int] NOT NULL,
      [Grade] [decimal](3, 2) NULL,

      CONSTRAINT [PK_StudentGrade] PRIMARY KEY CLUSTERED (
         [EnrollmentID] ASC
      )

      WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]

   ) ON [PRIMARY]

END
GO

Step 4 - एडिटर पर राइट-क्लिक करें और Execute चुनें।

Step 5- अपने डेटाबेस पर राइट-क्लिक करें और रिफ्रेश पर क्लिक करें। आपको अपने डेटाबेस में नई जोड़ी गई तालिका दिखाई देगी।

Step 6 - सर्वर एक्सप्लोरर में, अपने डेटाबेस पर फिर से राइट-क्लिक करें।

Step 7 - नई क्वेरी का चयन करें और अपने डेटाबेस में संग्रहीत प्रक्रिया को जोड़ने के लिए टी-एसक्यूएल संपादक में निम्नलिखित कोड दर्ज करें, जो छात्र ग्रेड वापस कर देगा।

IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = 
   OBJECT_ID(N'[dbo].[GetStudentGrades]') AND type in (N'P', N'PC'))

BEGIN

   EXEC dbo.sp_executesql @statement = N'
   CREATE PROCEDURE [dbo].[GetStudentGrades]
   @StudentID int
   AS
   SELECT EnrollmentID, Grade, CourseID, StudentID FROM dbo.StudentGrade 
   WHERE StudentID = @StudentID
   '
END
GO

Step 8 - एडिटर पर राइट-क्लिक करें और Execute चुनें।

Step 9- अपने डेटाबेस पर राइट-क्लिक करें और रिफ्रेश पर क्लिक करें। आप देखेंगे कि आपके डेटाबेस में एक संग्रहीत प्रक्रिया बनाई गई है।

Step 10 - समाधान एक्सप्लोरर में परियोजना के नाम पर राइट-क्लिक करें और जोड़ें → नई आइटम का चयन करें।

Step 11 - इसके बाद Templates फलक में ADO.NET Entity Data Model को चुनें।

Step 12 - नाम के रूप में SPModel दर्ज करें, और फिर जोड़ें पर क्लिक करें।

Step 13 - मॉडल सामग्री चुनें संवाद बॉक्स में, डेटाबेस से EF डिजाइनर का चयन करें और फिर अगला क्लिक करें।

Step 14 - अपने डेटाबेस का चयन करें और अगला क्लिक करें।

Step 15 - अपने डेटाबेस ऑब्जेक्ट चुनें संवाद बॉक्स में तालिकाओं, विचारों पर क्लिक करें।

Step 16 - संग्रहीत कार्यविधियाँ और कार्य नोड के तहत स्थित GetStudentGradesForCourse फ़ंक्शन का चयन करें और समाप्त पर क्लिक करें।

Step 17 - व्यू → अन्य विंडोज → एंटिटी डेटा मॉडल ब्राउज़र का चयन करें और फ़ंक्शन इंपोर्ट्स के तहत GetStudentGrades पर राइट-क्लिक करें और संपादित करें का चयन करें।

यह निम्नलिखित संवाद का उत्पादन करेगा।

Step 18 - एंटिटीज रेडियो बटन पर क्लिक करें और स्टंबोबॉक्स से स्टूडेंटग्रेड को इस संग्रहित प्रक्रिया के रिटर्न प्रकार के रूप में चुनें और ओके पर क्लिक करें।

आइए निम्नलिखित सी # कोड पर एक नज़र डालें, जिसमें गेटस्टूडेंटग्रैड्स संग्रहीत प्रक्रिया में पैरामीटर के रूप में छात्र आईडी पास करके सभी ग्रेड प्राप्त किए जाएंगे।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         int studentID = 22;
         var studentGrades = context.GetStudentGrades(studentID);

         foreach (var student in studentGrades) {
            Console.WriteLine("Course ID: {0}, Title: {1}, Grade: {2} ", 
               student.CourseID, student.Course.Title, student.Grade);
         }

         Console.ReadKey();

      }
   }
}

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

Course ID: 4022, Title: Microeconomics, Grade: 3.00
Course ID: 4041, Title: Macroeconomics, Grade: 3.50

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

इस अध्याय में, आइए देखें कि किसी संदर्भ द्वारा ट्रैक नहीं की जा रही संस्थाओं में परिवर्तन कैसे करें। जिन संदर्भों को एक संदर्भ द्वारा ट्रैक नहीं किया जा रहा है, उन्हें 'डिस्कनेक्टेड' संस्थाओं के रूप में जाना जाता है।

  • अधिकांश एकल-स्तरीय अनुप्रयोगों के लिए, जहाँ उपयोगकर्ता इंटरफ़ेस और डेटाबेस एक्सेस लेयर्स एक ही आवेदन प्रक्रिया में चलते हैं, आप संभवतः केवल उन संस्थाओं पर कार्य कर रहे होंगे जिन्हें किसी संदर्भ द्वारा ट्रैक किया जा रहा है।

  • एन-टियर अनुप्रयोगों में डिस्कनेक्टेड संस्थाओं पर संचालन बहुत अधिक सामान्य है।

  • एन-टियर एप्लिकेशन में एक सर्वर पर कुछ डेटा प्राप्त करना और इसे नेटवर्क पर, क्लाइंट मशीन पर वापस करना शामिल है।

  • क्लाइंट एप्लिकेशन इसके बाद सर्वर पर बने रहने के लिए इसे वापस करने से पहले इस डेटा में हेरफेर करता है।

निम्नलिखित दो चरण हैं जिन्हें डिस्कनेक्ट किए गए इकाई ग्राफ या यहां तक ​​कि एकल डिस्कनेक्ट किए गए इकाई के साथ लेने की आवश्यकता है।

  • नए संदर्भ उदाहरण के साथ संस्थाओं को संलग्न करें और इन संस्थाओं के बारे में संदर्भ को जागरूक करें।

  • मैन्युअल रूप से इन संस्थाओं के लिए उपयुक्त EntityStates सेट करें।

आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें छात्र इकाई को दो नामांकन संस्थाओं के साथ जोड़ा गया है।

class Program {

   static void Main(string[] args) {

      var student = new Student {

         ID = 1001,
         FirstMidName = "Wasim",
         LastName = "Akram", 

         EnrollmentDate = DateTime.Parse("2015-10-10"), 
            Enrollments = new List<Enrollment> {

               new Enrollment{EnrollmentID = 2001,CourseID = 4022, StudentID = 1001 },
               new Enrollment{EnrollmentID = 2002,CourseID = 4025, StudentID = 1001 },
         }
      };

      using (var context = new UniContextEntities()) {

         context.Students.Add(student);
         Console.WriteLine("New Student ({0} {1}): {2}", 
            student.FirstMidName, student.LastName, context.Entry(student).State);

         foreach (var enrollment in student.Enrollments) {
            Console.WriteLine("Enrollment ID: {0} State: {1}", 
               enrollment.EnrollmentID, context.Entry(enrollment).State);
         }

         Console.WriteLine("Press any key to exit...");
         Console.ReadKey();
      }
   } 
}
  • कोड एक नया छात्र उदाहरण बनाता है, जो अपनी नामांकन संपत्ति में दो नए नामांकन उदाहरणों का संदर्भ देता है।

  • फिर Add Method का उपयोग करके नए छात्र को एक संदर्भ में जोड़ा जाता है।

  • छात्र के जुड़ जाने के बाद, कोड उस ट्रैकिंग सूचना का उपयोग करने के लिए DbContext.Entry विधि का उपयोग करता है, जिसमें Entity फ्रेमवर्क नए छात्र के बारे में है।

  • इस परिवर्तन ट्रैकिंग सूचना से, राज्य की संपत्ति का उपयोग इकाई की वर्तमान स्थिति को लिखने के लिए किया जाता है।

  • यह प्रक्रिया तब नए बनाए गए प्रत्येक नामांकन के लिए दोहराई जाती है जिसे नए छात्र से संदर्भित किया जाता है। यदि आप एप्लिकेशन चलाते हैं, तो आपको निम्न आउटपुट प्राप्त होंगे -

New Student   (Wasim  Akram): Added
Enrollment ID: 2001 State: Added
Enrollment ID: 2002 State: Added
Press any key to exit...

जबकि DbSet.Add का उपयोग एंटिटी फ्रेमवर्क को नई संस्थाओं के बारे में बताने के लिए किया जाता है, DbSet.Attach का उपयोग एंटिटी फ्रेमवर्क को मौजूदा संस्थाओं के बारे में बताने के लिए किया जाता है। अटैच विधि अपरिवर्तित स्थिति में एक इकाई को चिह्नित करेगी।

आइए निम्नलिखित सी # कोड पर एक नज़र डालें जिसमें एक डिस्कनेक्ट की गई इकाई DCContext के साथ जुड़ी हुई है।

class Program {

   static void Main(string[] args) {

      var student = new Student {

         ID = 1001,
         FirstMidName = "Wasim",
         LastName = "Akram",
         EnrollmentDate = DateTime.Parse("2015-10-10"), 

         Enrollments = new List<Enrollment> {
            new Enrollment { EnrollmentID = 2001, CourseID = 4022, StudentID = 1001 },
            new Enrollment { EnrollmentID = 2002, CourseID = 4025, StudentID = 1001 },
         }
			
      };

      using (var context = new UniContextEntities()) {

         context.Students.Attach(student);
         Console.WriteLine("New Student ({0} {1}): {2}", 
            student.FirstMidName, student.LastName, context.Entry(student).State);

         foreach (var enrollment in student.Enrollments) {
            Console.WriteLine("Enrollment ID: {0} State: {1}", enrollment.EnrollmentID, 
               context.Entry(enrollment).State);
         }

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

जब उपरोक्त कोड अटैच () विधि से निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा।

New Student   (Wasim  Akram): Unchanged
Enrollment ID: 2001 State: Unchanged
Enrollment ID: 2002 State: Unchanged
Press any key to exit...

इस अध्याय में, आइए जानें कि एन्टिटी फ्रेमवर्क डिज़ाइनर का उपयोग करके टेबल-वैल्यूड फंक्शन्स (TVFs) को मैप कैसे करें और LINQ क्वेरी से TVF कैसे कॉल करें।

  • TVFs वर्तमान में केवल डेटाबेस प्रथम वर्कफ़्लो में समर्थित हैं।

  • इसे पहली बार एंटिटी फ्रेमवर्क संस्करण 5 में पेश किया गया था।

  • TVF का उपयोग करने के लिए आपको .NET फ्रेमवर्क 4.5 या इसके बाद के संस्करण को लक्षित करना होगा।

  • यह संग्रहीत प्रक्रियाओं के समान है, लेकिन एक प्रमुख अंतर के साथ, यानी, एक टीवीएफ का परिणाम देखने योग्य है। इसका मतलब यह है कि TVF के परिणाम LINQ क्वेरी में उपयोग किए जा सकते हैं जबकि संग्रहीत कार्यविधि के परिणाम नहीं हो सकते।

चलिए फाइल → न्यू → प्रोजेक्ट से एक नया प्रोजेक्ट बनाने के निम्नलिखित उदाहरण पर एक नज़र डालते हैं।

Step 1 - मध्य फलक से कंसोल एप्लिकेशन का चयन करें और नाम फ़ील्ड में TableValuedFunctionDemo दर्ज करें।

Step 2 - सर्वर एक्सप्लोरर में अपने डेटाबेस पर राइट-क्लिक करें।

Step 3 - नई क्वेरी का चयन करें और अपने डेटाबेस में एक नई तालिका जोड़ने के लिए T-SQL संपादक में निम्न कोड दर्ज करें।

IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id =
   OBJECT_ID(N'[dbo].[StudentGrade]') AND type in (N'U'))

BEGIN

   CREATE TABLE [dbo].[StudentGrade](

      [EnrollmentID] [int] IDENTITY(1,1) NOT NULL,
      [CourseID] [int] NOT NULL,
      [StudentID] [int] NOT NULL,
      [Grade] [decimal](3, 2) NULL,

      CONSTRAINT [PK_StudentGrade] PRIMARY KEY CLUSTERED ([EnrollmentID] ASC)

      WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]

   ) ON [PRIMARY]

END
GO

Step 4 - एडिटर पर राइट-क्लिक करें और Execute चुनें।

Step 5- अपने डेटाबेस पर राइट-क्लिक करें और रिफ्रेश पर क्लिक करें। आपको अपने डेटाबेस में नई जोड़ी गई तालिका दिखाई देगी।

Step 6- अब एक फ़ंक्शन बनाएं जो छात्र ग्रेड को निश्चित रूप से वापस कर देगा। T-SQL संपादक में निम्न कोड दर्ज करें।

CREATE FUNCTION [dbo].[GetStudentGradesForCourse]

(@CourseID INT)

RETURNS TABLE

RETURN
   SELECT [EnrollmentID],
      [CourseID],
      [StudentID],
      [Grade]
   FROM   [dbo].[StudentGrade]
   WHERE  CourseID = @CourseID

Step 7 - एडिटर पर राइट-क्लिक करें और Execute चुनें।

अब आप देख सकते हैं कि फ़ंक्शन बनाया गया है।

Step 8 - समाधान एक्सप्लोरर में प्रोजेक्ट के नाम पर राइट क्लिक करें और Add → New Item चुनें।

Step 9 - इसके बाद Templates फलक में ADO.NET Entity Data Model को चुनें।

Step 10 - नाम के रूप में TVFModel दर्ज करें, और फिर जोड़ें पर क्लिक करें।

Step 11 - मॉडल सामग्री चुनें संवाद बॉक्स में, डेटाबेस से EF डिजाइनर का चयन करें और फिर अगला क्लिक करें।

Step 12 - अपने डेटाबेस का चयन करें और अगला क्लिक करें।

Step 13 - अपने डेटाबेस ऑब्जेक्ट चुनें संवाद बॉक्स में तालिकाओं, विचारों का चयन करें।

Step 14 - संग्रहीत कार्यविधियाँ और कार्य नोड के तहत स्थित GetStudentGradesForCourse फ़ंक्शन का चयन करें और समाप्त पर क्लिक करें।

Step 15 - व्यू → अन्य विंडोज → एंटिटी डेटा मॉडल ब्राउज़र का चयन करें और फ़ंक्शन इंपोर्ट्स के तहत GetStudentGradesForCourse पर राइट-क्लिक करें और एडिट चुनें।

आप निम्नलिखित संवाद देखेंगे।

Step 16 - एंटिटीज रेडियो बटन पर क्लिक करें और इस फंक्शन के रिटर्न टाइप के रूप में कॉम्बोक्स से एनरोलमेंट चुनें और ओके पर क्लिक करें।

आइए निम्नलिखित सी # कोड पर एक नज़र डालें जिसमें उन सभी छात्रों के ग्रेड को पुनः प्राप्त किया जाएगा जो डेटाबेस में कोर्स आईडी = 4022 में नामांकित हैं।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         var CourseID = 4022;

         // Return all the best students in the Microeconomics class.
         var students = context.GetStudentGradesForCourse(CourseID);

         foreach (var result in students) {
            Console.WriteLine("Student ID:  {0}, Grade: {1}",
               result.StudentID, result.Grade);
         }

         Console.ReadKey();
      }
   }
}

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

Student ID: 1, Grade: 2
Student ID: 4, Grade: 4
Student ID: 9, Grade: 3.5

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

इकाई ढांचे में आप LINQ का उपयोग करके अपनी इकाई कक्षाओं के साथ क्वेरी कर सकते हैं। आप DbCOntext का उपयोग करके डेटाबेस के खिलाफ सीधे कच्चे SQL का उपयोग करके क्वेरी भी चला सकते हैं। तकनीकों को समान रूप से कोड प्रथम और ईएफ डिजाइनर के साथ बनाए गए मॉडल के लिए लागू किया जा सकता है।

मौजूदा क्वेरी पर SQL क्वेरी

DbSet पर SqlQuery पद्धति एक कच्ची SQL क्वेरी को लिखने के लिए अनुमति देती है जो इकाई उदाहरणों को वापस कर देगी। लौटी हुई वस्तुओं को संदर्भ द्वारा ट्रैक किया जाएगा जैसे कि वे एक LINQ क्वेरी द्वारा लौटाए गए थे। उदाहरण के लिए -

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         var students = context.Students.SqlQuery("SELECT * FROM dbo.Student").ToList();

         foreach (var student in students) {
            string name = student.FirstMidName + " " + student.LastName;
            Console.WriteLine("ID: {0}, Name: {1}, \tEnrollment Date {2} ",
               student.ID, name, student.EnrollmentDate.ToString());
         }

         Console.ReadKey();
      }
   }
}

उपरोक्त कोड डेटाबेस से सभी छात्रों को पुनः प्राप्त करेगा।

गैर-इकाई प्रकारों के लिए SQL क्वेरी

डेटाबेस वर्ग पर SqlQuery विधि का उपयोग करके आदिम प्रकारों सहित किसी भी प्रकार की रिटर्निंग SQL क्वेरी इंस्टेंसेस बनाई जा सकती है। उदाहरण के लिए -

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         var studentNames = context.Database.SqlQuery
            <string>("SELECT FirstMidName FROM dbo.Student").ToList();

         foreach (var student in studentNames) {
            Console.WriteLine("Name: {0}", student);
         }

         Console.ReadKey();
      }
   }
}

SQL डेटाबेस में शामिल हो जाता है

ExecuteSqlCommnad विधि का उपयोग डेटाबेस में गैर-क्वेरी आदेश भेजने के लिए किया जाता है, जैसे इन्सर्ट, अपडेट या डिलीट कमांड। आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें छात्र का पहला नाम आईडी = 1 के रूप में अपडेट किया गया है

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         //Update command

         int noOfRowUpdated = context.Database.ExecuteSqlCommand("Update 
            student set FirstMidName = 'Ali' where ID = 1");

         context.SaveChanges();

         var student = context.Students.SqlQuery("SELECT * FROM
            dbo.Student where ID = 1").Single();

         string name = student.FirstMidName + " " + student.LastName;

         Console.WriteLine("ID: {0}, Name: {1}, \tEnrollment Date {2} ", 
            student.ID, name, student.EnrollmentDate.ToString());

         Console.ReadKey();
      }
   }
}

उपरोक्त कोड डेटाबेस से सभी छात्रों के पहले नाम को पुनः प्राप्त करेगा।

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

  • संपीड़ित प्रकार के सभी प्रकार के लाभ होते हैं जब उन संपत्तियों के साथ काम करते हैं जिनकी निश्चित संख्या में प्रतिक्रियाएं होती हैं।

  • जब आप एन्यूमरेशन का उपयोग करते हैं तो किसी एप्लिकेशन की सुरक्षा और विश्वसनीयता दोनों बढ़ जाती है।

  • गणना करना उपयोगकर्ता को गलतियों के लिए बहुत कठिन बनाता है, और इंजेक्शन हमलों जैसे मुद्दे कोई भी नहीं हैं।

  • एंटिटी फ्रेमवर्क में, एक गणना में निम्नलिखित अंतर्निहित प्रकार हो सकते हैं -

    • Byte
    • Int16
    • Int32
    • Int64
    • SByte
  • गणन तत्वों का डिफ़ॉल्ट अंतर्निहित प्रकार अंतर है।

  • डिफ़ॉल्ट रूप से, पहले एन्यूमरेटर का मान 0 होता है, और प्रत्येक क्रमिक एन्यूमरेटर का मान 1 से बढ़ जाता है।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें हम डिजाइनर में एक इकाई का निर्माण करेंगे और फिर कुछ गुणों को जोड़ेंगे।

Step 1 - फ़ाइल → नई → परियोजना मेनू विकल्प से नई परियोजना बनाएँ।

Step 2 - बाएं फलक में, कंसोल एप्लिकेशन चुनें।

Step 3 - प्रोजेक्ट के नाम के रूप में EFEnumDemo डालें और ओके पर क्लिक करें।

Step 4 - समाधान एक्सप्लोरर में परियोजना के नाम पर राइट-क्लिक करें और जोड़ें → नई आइटम मेनू विकल्प चुनें।

Step 5 - Templates फलक में ADO.NET इकाई डेटा मॉडल का चयन करें।

Step 6 - फ़ाइल नाम के लिए EFEnumModel.edmx दर्ज करें, और फिर जोड़ें पर क्लिक करें।

Step 7 - इकाई डेटा मॉडल विज़ार्ड पृष्ठ पर, खाली ईएफ डिजाइनर मॉडल का चयन करें।

Step 8 - नीचे क्लिक करें

Step 9 - इसके बाद डिजाइनर विंडो पर राइट क्लिक करें और Add → Entity चुनें।

नई एंटिटी संवाद बॉक्स निम्न छवि में दिखाया गया है।

Step 10 - एक संपत्ति के नाम के रूप में एक विभाग का नाम और विभाग के रूप में दर्ज करें, संपत्ति प्रकार को Int32 के रूप में छोड़ दें और ठीक पर क्लिक करें।

Step 11 - इकाई पर राइट क्लिक करें और Add New → Scalar Property चुनें।

Step 12 - विभाग को नई संपत्ति का नाम बदलें।

Step 13 - नई संपत्ति का प्रकार बदलकर Int32 (डिफ़ॉल्ट रूप से, नई संपत्ति स्ट्रिंग प्रकार का है)।

Step 14 - प्रकार बदलने के लिए, गुण विंडो खोलें और प्रकार गुण को Int32 में बदलें।

Step 15 - एंटिटी फ्रेमवर्क डिज़ाइनर में, नाम प्रॉपर्टी पर राइट क्लिक करें, Convert to enum चुनें।

Step 16 - Enum टाइप करें संवाद बॉक्स में, Enum टाइप नाम के लिए डिपार्टमेंटनाम दर्ज करें, अंडरसिव टाइप को Int32 में बदलें, और उसके बाद निम्न सदस्यों को टाइप में जोड़ें: भौतिकी, रसायन विज्ञान, कंप्यूटर और अर्थशास्त्र।

Step 17 - क्लिक करें।

यदि आप मॉडल ब्राउज़र विंडो में स्विच करते हैं, तो आप देखेंगे कि टाइप एनम टाइप नोड में भी जोड़ा गया था।

आइए मॉडल प्रथम दृष्टिकोण अध्याय में वर्णित सभी चरणों का पालन करके मॉडल से डेटाबेस उत्पन्न करें।

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

जनरेट डेटाबेस विज़ार्ड का अपना डेटा कनेक्शन डायलॉग बॉक्स चुनें।

Step 2 - न्यू कनेक्शन बटन पर क्लिक करें।

Step 3 - डेटाबेस के लिए सर्वर नाम और EnumDemo दर्ज करें और ठीक पर क्लिक करें।

Step 4 - यदि आप एक नया डेटाबेस बनाना चाहते हैं तो एक संवाद पॉप अप होगा, हाँ पर क्लिक करें।

Step 5- अगला पर क्लिक करें और डेटाबेस बनाएँ विज़ार्ड डेटा डेटाबेस बनाने के लिए डेटा परिभाषा भाषा (DDL) उत्पन्न करता है। अब समाप्त पर क्लिक करें।

Step 6 - T-SQL Editor पर राइट-क्लिक करें और Execute चुनें।

Step 7 - उत्पन्न स्कीमा को देखने के लिए, SQL सर्वर ऑब्जेक्ट एक्सप्लोरर में डेटाबेस के नाम पर राइट क्लिक करें और रिफ्रेश का चयन करें।

आप डेटाबेस में विभाग तालिका देखेंगे।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें संदर्भ के लिए कुछ नए विभाग ऑब्जेक्ट जोड़े और सहेजे गए हैं। और फिर कंप्यूटर विभाग को पुनः प्राप्त करें।

class Program {

   static void Main(string[] args) {

      using (var context = new EFEnumModelContainer()) {

         context.Departments.Add(new Department { DeptName = DepartmentNames.Physics});
         context.Departments.Add(new Department { DeptName = DepartmentNames.Computer});
         context.Departments.Add(new Department { DeptName = DepartmentNames.Chemistry});
         context.Departments.Add(new Department { DeptName = DepartmentNames.Economics});

         context.SaveChanges();

         var department = (
            from d in context.Departments
            where d.DeptName == DepartmentNames.Computer
            select d
         ).FirstOrDefault();

         Console.WriteLine(
            "Department ID: {0}, Department Name: {1}", 
               department.DeptID, department.DeptName
         );

         Console.ReadKey();
      }
   }
}

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

Department ID: 2, Department Name: Computer

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

Asynchronous programmingपृष्ठभूमि में संचालन निष्पादित करना शामिल है ताकि मुख्य धागा अपने स्वयं के संचालन को जारी रख सके। इस तरह मुख्य धागा उपयोगकर्ता इंटरफ़ेस को उत्तरदायी रख सकता है जबकि पृष्ठभूमि धागा हाथ में कार्य को संसाधित कर रहा है।

  • एंटिटी फ्रेमवर्क 6.0 डेटा की क्वेरी और बचत के लिए अतुल्यकालिक संचालन का समर्थन करता है।

  • अतुल्यकालिक संचालन आपके आवेदन को निम्नलिखित तरीकों से मदद कर सकता है -

    • अपने एप्लिकेशन को उपयोगकर्ता इंटरैक्शन के लिए अधिक उत्तरदायी बनाएं
    • अपने आवेदन के समग्र प्रदर्शन में सुधार करें
  • आप विभिन्न तरीकों से अतुल्यकालिक संचालन निष्पादित कर सकते हैं। लेकिन async / wait कीवर्ड .NET फ्रेमवर्क 4.5 में पेश किए गए थे जो आपके काम को सरल बनाता है।

  • केवल एक चीज जिसे आपको अनुसरण करने की आवश्यकता है, वह है async / प्रतीक्षा पैटर्न जैसा कि निम्नलिखित कोड टुकड़ा द्वारा सचित्र है।

आइए निम्नलिखित उदाहरण (async / प्रतीक्षा का उपयोग किए बिना) पर एक नज़र डालें, जिसमें DatabaseOperations विधि डेटाबेस में एक नए छात्र को बचाता है और फिर सभी छात्रों को डेटाबेस से पुनर्प्राप्त करता है और अंत में कंसोल पर कुछ अतिरिक्त संदेश मुद्रित होता है।

class Program {

   static void Main(string[] args) {
      Console.WriteLine("Database Operations Started");
      DatabaseOperations();
		
      Console.WriteLine();
      Console.WriteLine("Database Operations Completed");
      Console.WriteLine();
      Console.WriteLine("Entity Framework Tutorials");
      Console.ReadKey();
   }

   public static void DatabaseOperations() {

      using (var context = new UniContextEntities()) {

         // Create a new student and save it

         context.Students.Add(new Student {
            FirstMidName = "Akram", 
            LastName = "Khan", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())});

         Console.WriteLine("Calling SaveChanges.");
         context.SaveChanges();
         Console.WriteLine("SaveChanges completed.");

         // Query for all Students ordered by first name

         var students = (from s in context.Students
            orderby s.FirstMidName select s).ToList();

         // Write all students out to Console

         Console.WriteLine();
         Console.WriteLine("All Student:");

         foreach (var student in students) {
            string name = student.FirstMidName + " " + student.LastName;
            Console.WriteLine(" " + name);
         }
      }
   }
}

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

Calling SaveChanges.
SaveChanges completed.
All Student:
Akram Khan
Ali Khan
Ali Alexander
Arturo Anand
Bill Gates
Gytis Barzdukas
Laura  Nornan
Meredith fllonso
Nino Olioetto
Peggy Justice
Yan Li

Entity Framework Tutorials

आइए नए async का उपयोग करें और कीवर्ड की प्रतीक्षा करें और Program.cs पर निम्न परिवर्तन करें

  • System.Data.Entity नामस्थान जोड़ें जो EF को async एक्सटेंशन मेथड देगा।

  • System.Threading.Tasks नाम स्थान जोड़ें जो हमें टास्क प्रकार का उपयोग करने की अनुमति देगा।

  • अपडेट करें DatabaseOperations के रूप में चिह्नित किया जाना है async और वापस आ जाओ Task

  • SaveChanges के Async संस्करण को कॉल करें और इसके पूरा होने का इंतजार करें।

  • ToList के Async संस्करण को कॉल करें और परिणाम की प्रतीक्षा करें।

class Program {

   static void Main(string[] args) {
      var task = DatabaseOperations();
      Console.WriteLine();
      Console.WriteLine("Entity Framework Tutorials");
      task.Wait();
      Console.ReadKey();
   }

   public static async Task DatabaseOperations() {

      using (var context = new UniContextEntities()) {

         // Create a new blog and save it

         context.Students.Add(new Student {
            FirstMidName = "Salman", 
            LastName = "Khan", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())});

         Console.WriteLine("Calling SaveChanges.");
         await context.SaveChangesAsync();
         Console.WriteLine("SaveChanges completed.");

         // Query for all Students ordered by first name

         var students = await (from s in context.Students 
            orderby s.FirstMidName select s).ToListAsync();

         // Write all students out to Console

         Console.WriteLine();
         Console.WriteLine("All Student:");

         foreach (var student in students) {
            string name = student.FirstMidName + " " + student.LastName; 
            Console.WriteLine(" " + name);
         }
      }
   }
}

निष्पादन पर, यह निम्नलिखित आउटपुट का उत्पादन करेगा।

Calling SaveChanges.
Entity Framework Tutorials
SaveChanges completed.
All Student:
Akram Khan
Ali Khan
Ali Alexander
Arturo Anand
Bill Gates
Gytis Barzdukas
Laura  Nornan
Meredith fllonso
Nino Olioetto
Peggy Justice
Salman Khan
Yan Li

अब जब कोड अतुल्यकालिक है, तो आप अपने कार्यक्रम के एक अलग निष्पादन प्रवाह का निरीक्षण कर सकते हैं।

  • SaveChanges नए छात्र को डेटाबेस में धकेलना शुरू कर देता है और फिर DatabaseOperations विधि वापस आ जाती है (भले ही इसे निष्पादित करना समाप्त नहीं हुआ है) और मुख्य विधि में प्रोग्राम फ्लो जारी है।

  • संदेश तब कंसोल को लिखा जाता है।

  • डेटाबेस ऑपरेशन पूरा होने तक प्रतीक्षा थ्रेड पर प्रबंधित थ्रेड अवरुद्ध है। एक बार जब यह पूरा हो जाता है, तो हमारे डेटाबेस के शेष कार्य निष्पादित हो जाएंगे।

  • SaveChanges पूरा करता है।

  • डेटाबेस से सभी छात्र को प्राप्त किया और कंसोल को लिखा गया है।

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

एंटिटी फ्रेमवर्क अब आपको एंटिटी फ्रेमवर्क से अवगत कराने के लिए एंटिटी फ्रेमवर्क से लाभ उठाने की अनुमति देता है, एंटिटी फ्रेमवर्क के बारे में पता करने के लिए, बुनियादी ढांचे से संस्थाओं को अलग करना। आप ऐसी कक्षाएं बना सकते हैं जो उनके व्यवसाय के नियमों पर ध्यान केंद्रित किए बिना यह बता सकती हैं कि वे कैसे बनी रहती हैं (जहां डेटा संग्रहीत किया जाता है और आपकी वस्तुओं के बीच डेटा आगे-पीछे कैसे होता है)।

लगातार अज्ञानी संस्थाओं का निर्माण

पूर्ववर्ती पैराग्राफ ने एक ऐसी विधि का वर्णन किया जिसमें डेटा के स्रोत का कोई अंतरंग ज्ञान नहीं है जो वह खपत करता है। यह दृढ़ता अज्ञानता के सार को उजागर करता है, जो तब होता है जब आपकी कक्षाएं और उनके आसपास हमारे कई एप्लिकेशन परतें परवाह नहीं करती हैं कि डेटा कैसे संग्रहीत किया जाता है।

  • Entity Framework के .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

असम्बद्ध परिदृश्य

असम्बद्ध परिदृश्य वह है जब कोई इकाई डेटाबेस से पुनर्प्राप्त की जाती है और विभिन्न संदर्भों में संशोधित की जाती है। मान लीजिए कि हम कुछ डेटा को एक प्रेजेंटेशन लेयर में प्रदर्शित करना चाहते हैं और हम कुछ एन-टियर एप्लिकेशन का उपयोग कर रहे हैं, इसलिए बेहतर होगा कि संदर्भ को खोलें, डेटा को लाएं और अंत में संदर्भ को बंद करें। चूंकि यहां हमने डेटा प्राप्त किया है और संदर्भ को बंद कर दिया है, इसलिए जिन संस्थाओं को हमने लिया है वे अब ट्रैक नहीं किए गए हैं और यह डिस्कनेक्ट परिदृश्य है।

आइए निम्नलिखित कोड पर एक नज़र डालते हैं, जिसमें नई डिस्कनेक्टेड स्टूडेंट इकाई को ऐड मेथड का उपयोग करके एक संदर्भ में जोड़ा जाता है।

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

LINQ संस्थाओं को

LINQ to Entities को समझने के लिए सबसे महत्वपूर्ण अवधारणाओं में से एक यह है कि यह एक घोषित भाषा है। ध्यान इस बात पर केंद्रित है कि आपको जानकारी प्राप्त करने की आवश्यकता के बजाय किस जानकारी की आवश्यकता है।

  • इसका मतलब है कि आप डेटा के साथ काम करने में अधिक समय बिता सकते हैं और डेटाबेस को एक्सेस करने जैसे कार्यों को करने के लिए आवश्यक अंतर्निहित कोड को जानने की कोशिश कर रहे हैं।

  • यह समझना महत्वपूर्ण है कि घोषित भाषाएं वास्तव में डेवलपर से कोई नियंत्रण नहीं हटाती हैं, लेकिन यह डेवलपर को ध्यान देने में मदद करती है कि महत्वपूर्ण क्या है।

LINQ से एंटिटीज आवश्यक कीवर्ड

LINQ क्वेरी बनाने के लिए उपयोग किए जाने वाले मूल खोजशब्दों को जानना महत्वपूर्ण है। याद रखने के लिए केवल कुछ कीवर्ड हैं, लेकिन आप उन्हें विशिष्ट परिणाम प्राप्त करने के लिए विभिन्न तरीकों से जोड़ सकते हैं। निम्न सूची में ये मूल कीवर्ड हैं और प्रत्येक का एक सरल विवरण प्रदान करता है।

अनु क्रमांक। कीवर्ड और विवरण
1

Ascending

निर्दिष्ट करता है कि किसी श्रेणी का कम से कम (या निम्नतम) तत्व किसी श्रेणी के उच्चतम तत्व तक होता है। यह सामान्य रूप से डिफ़ॉल्ट सेटिंग है। उदाहरण के लिए, जब एक अल्फ़ाबेटिक प्रकार का प्रदर्शन करते हैं, तो सॉर्ट ए से जेड तक की सीमा में होगा।

2

By

एक समूह को लागू करने के लिए उपयोग किए जाने वाले क्षेत्र या अभिव्यक्ति को निर्दिष्ट करता है। क्षेत्र या अभिव्यक्ति समूहन कार्य करने के लिए उपयोग की जाने वाली कुंजी को परिभाषित करती है।

3

Descending

निर्दिष्ट करता है कि किसी श्रेणी के सबसे बड़े (या उच्चतम) तत्व से लेकर श्रेणी के निम्नतम तत्व तक छँटाई होती है। उदाहरण के लिए, जब एक अल्फ़ाबेटिक सॉर्ट करते हैं, तो सॉर्ट ज़ेड से ए तक की सीमा में होगा।

4

Equals

प्राथमिक संदर्भ डेटा स्रोत को द्वितीयक संदर्भ डेटा स्रोत में शामिल करने के लिए एक सम्मिलित कथन के बाएँ और दाएँ खंड के बीच उपयोग किया जाता है। बराबर कीवर्ड के बाईं ओर का फ़ील्ड या अभिव्यक्ति प्राथमिक डेटा स्रोत को निर्दिष्ट करता है, जबकि बराबर कीवर्ड के दाईं ओर फ़ील्ड या अभिव्यक्ति द्वितीयक डेटा स्रोत को निर्दिष्ट करता है।

5

From

आवश्यक जानकारी प्राप्त करने के लिए उपयोग किए जाने वाले डेटा स्रोत को निर्दिष्ट करता है और एक रेंज चर को परिभाषित करता है। इस चर का एक ही उद्देश्य है जैसे कि लूप में पुनरावृत्ति के लिए उपयोग किया जाने वाला चर।

6

Group

आपके द्वारा निर्दिष्ट प्रमुख मूल्य का उपयोग करके समूहों में आउटपुट को व्यवस्थित करता है। आउटपुट संगठन के कई स्तर बनाने के लिए कई समूह खंडों का उपयोग करें। समूह खंड का क्रम उस गहराई को निर्धारित करता है जिस पर एक विशेष कुंजी मान समूह क्रम में प्रकट होता है। आप एक विशिष्ट संदर्भ बनाने के लिए इस कीवर्ड को साथ जोड़ते हैं।

7

In

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

8

Into

एक पहचानकर्ता को निर्दिष्ट करता है जिसे आप LINQ क्वेरी क्लॉज़ के लिए एक संदर्भ के रूप में उपयोग कर सकते हैं जैसे कि join, group, और select।

9

Join

दो संबंधित डेटा स्रोतों से एक एकल डेटा स्रोत बनाता है, जैसे कि मास्टर / डिटेल सेटअप। एक जुड़ाव एक आंतरिक, समूह या बाएं-बाहरी जुड़ाव को निर्दिष्ट कर सकता है, आंतरिक रूप से डिफ़ॉल्ट के रूप में शामिल होता है। आप msdn.microsoft.com पर जुड़ने के बारे में अधिक पढ़ सकते हैं

10

Let

एक रेंज वैरिएबल को परिभाषित करता है जिसका उपयोग आप सबप्रेशन के परिणामों को क्वेरी अभिव्यक्ति में स्टोर करने के लिए कर सकते हैं। आमतौर पर, रेंज वैरिएबल का उपयोग अतिरिक्त एनुमरेटेड आउटपुट प्रदान करने या क्वेरी की दक्षता बढ़ाने के लिए किया जाता है (ताकि किसी विशेष कार्य, जैसे कि स्ट्रिंग के लोअरकेस मान को खोजने के लिए, एक बार से अधिक की आवश्यकता न हो)।

1 1

On

फ़ील्ड या अभिव्यक्ति निर्दिष्ट करता है जो किसी सम्मिलित को लागू करने के लिए उपयोग किया जाता है। क्षेत्र या अभिव्यक्ति एक ऐसे तत्व को परिभाषित करता है जो प्रासंगिक डेटा स्रोतों दोनों के लिए सामान्य है।

12

Orderby

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

13

Where

परिभाषित करता है कि LINQ को डेटा स्रोत से क्या प्राप्त करना चाहिए। आप एक या एक से अधिक बूलियन अभिव्यक्तियों का उपयोग करते हैं जो कि पुनर्प्राप्त करने की बारीकियों को परिभाषित करते हैं। बूलियन अभिव्यक्तियों को && (और) और || का उपयोग करके एक दूसरे से अलग किया जाता है (या) ऑपरेटरों।

14

Select

LINQ क्वेरी से आउटपुट को निर्धारित करता है कि किस सूचना को वापस लौटाया जाए। यह कथन डेटा प्रकार के तत्वों को परिभाषित करता है जो LINQ पुनरावृत्ति प्रक्रिया के दौरान लौटते हैं।

प्रक्षेपण

प्रोजेक्शन क्वेश्चन आपके डेटाबेस से केवल विशिष्ट फ़ील्ड्स को पुनः प्राप्त करके, आपके एप्लिकेशन की दक्षता में सुधार करते हैं।

  • आपके पास डेटा होने के बाद, आप आउटपुट से पहले डेटा को आकार देने के लिए आवश्यकतानुसार प्रोजेक्ट या फ़िल्टर करना चाह सकते हैं।

  • किसी भी LINQ से Entities के अभिव्यक्ति का मुख्य कार्य डेटा प्राप्त करना और इसे आउटपुट के रूप में प्रदान करना है।

इस चैप्टर का "विकासशील LINQ टू एंटिटीज क्वेश्चन" खंड इस मूल कार्य को करने के लिए तकनीकों को प्रदर्शित करता है।

आइए निम्नलिखित कोड पर एक नज़र डालें, जिसमें छात्रों की सूची पुनः प्राप्त की जाएगी।

using (var context = new UniContextEntities()) {

   var studentList = from s in context.Students select s;

   foreach (var student in studentList) {
      string name = student.FirstMidName + " " + student.LastName;
      Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
   }
}

एकल वस्तु

किसी एकल छात्र ऑब्जेक्ट को प्राप्त करने के लिए आप फ़र्स्ट () या फ़र्स्टऑर्डडफ़ॉल्ट एन्यूमरेबल विधियों का उपयोग कर सकते हैं जो अनुक्रम के पहले तत्व को लौटाता है। First और FirstOrDefault के बीच अंतर यह है कि First () एक अपवाद को फेंक देगा, अगर आपूर्ति किए गए मानदंड के लिए कोई परिणाम डेटा नहीं है जबकि FirstOrDefault () डिफ़ॉल्ट मान शून्य देता है, यदि कोई परिणाम डेटा नहीं है। नीचे दिए गए कोड स्निपेट में पहले छात्र को सूची से हटा दिया जाएगा, जिसका पहला नाम अली है।

using (var context = new UniContextEntities()) {

   var student = (from s in context.Students where s.FirstMidName 
      == "Ali" select s).FirstOrDefault<Student>();

   string name = student.FirstMidName + " " + student.LastName;
   Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
}

आप सिंगल स्टूडेंट ऑब्जेक्ट को प्राप्त करने के लिए सिंगल () या सिंगलऑर्डेफ़ॉल्ट का भी उपयोग कर सकते हैं, जो एक सीक्वेंस का सिंगल, विशिष्ट तत्व देता है। निम्नलिखित उदाहरण में, एक एकल छात्र को पुनः प्राप्त किया जाता है जिसकी आईडी 2 है।

using (var context = new UniContextEntities()) {

   var student = (from s in context.Students where s.ID 
      == 2 select s).SingleOrDefault<Student>();
   string name = student.FirstMidName + " " + student.LastName;
	
   Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
   Console.ReadKey();
}

वस्तुओं की सूची

यदि आप उन छात्रों की सूची पुनः प्राप्त करना चाहते हैं, जिनका पहला नाम अली है तो आप ToList () उपयोग करने योग्य विधि का उपयोग कर सकते हैं।

using (var context = new UniContextEntities()) {

   var studentList = (from s in context.Students where s.FirstMidName 
      == "Ali" select s).ToList();

   foreach (var student in studentList) {
      string name = student.FirstMidName + " " + student.LastName;
      Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
   }

   Console.ReadKey();
}

गण

किसी विशेष क्रम में डेटा / सूची को पुनः प्राप्त करने के लिए आप ऑर्डरबी कीवर्ड का उपयोग कर सकते हैं। निम्नलिखित कोड में, छात्र की स्निपेट सूची आरोही क्रम में प्राप्त की जाएगी।

using (var context = new UniContextEntities()) {

   var studentList = (from s in context.Students orderby
      s.FirstMidName ascending select s).ToList();

   foreach (var student in studentList) {
      string name = student.FirstMidName + " " + student.LastName;
      Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
   }

   Console.ReadKey();
}

स्टैंडर्ड बनाम प्रोजेक्शन एंटिटी फ्रेमवर्क क्वेरी

मान लीजिए, आपके पास एक छात्र मॉडल है जिसमें ID, FirstMidName, LastName और EnrollmentDate शामिल हैं। यदि आप छात्रों की सूची वापस करना चाहते हैं, तो सभी क्षेत्रों में एक मानक क्वेरी वापस आ जाएगी। लेकिन अगर आप केवल उन छात्रों की सूची प्राप्त करना चाहते हैं जिनमें ID, FirstMidName और LastName फ़ील्ड शामिल हैं। यह वह जगह है जहाँ आपको एक प्रक्षेपण क्वेरी का उपयोग करना चाहिए। निम्नलिखित प्रक्षेपण क्वेरी का सरल उदाहरण है।

using (var context = new UniContextEntities()) {

   var studentList = from s in context.Students
      orderby s.FirstMidName ascending
      where s.FirstMidName == "Ali"

   select new {s.ID, s.FirstMidName, s.LastName};

   foreach (var student in studentList) {
      string name = student.FirstMidName + " " + student.LastName;
      Console.WriteLine("ID : {0}, Name: {1}", student.ID, name);
   }

   Console.ReadKey();
}

ऊपर दिए गए प्रोजेक्शन क्वेरी को EnrolmentDate फ़ील्ड से बाहर रखा गया है। इससे आपका आवेदन बहुत जल्दी हो जाएगा।

एंटिटी फ्रेमवर्क 6.0 में, एक नई सुविधा शुरू की गई है जिसे इस रूप में जाना जाता है Logging SQL। इकाई फ्रेमवर्क के साथ काम करते समय, यह सीआरयूडी (क्रिएट, रीड, अपडेट और डिलीट) ऑपरेशन करने के लिए कमांड या समकक्ष SQL क्वेरी को डेटाबेस में भेजता है।

  • एंटिटी फ्रेमवर्क की यह विशेषता एंटिटी फ्रेमवर्क द्वारा उत्पन्न एक समान SQL क्वेरी को आंतरिक रूप से कैप्चर करना और इसे आउटपुट के रूप में प्रदान करना है।

  • एंटिटी फ्रेमवर्क 6 से पहले, जब भी डेटाबेस क्वेश्चन और कमांड को ट्रेस करने की आवश्यकता होती थी, डेवलपर के पास उपयोगिता या डेटाबेस ट्रेसिंग टूल के साथ थर्ड पार्टी पार्टीशन का उपयोग करने के अलावा कोई विकल्प नहीं होता था।

  • एंटिटी फ्रेमवर्क 6 में, यह नया फीचर एंटिटी फ्रेमवर्क द्वारा किए गए सभी ऑपरेशनों को लॉग इन करके एक सरल तरीका प्रदान करता है।

  • एंटिटी फ्रेमवर्क द्वारा की जाने वाली सभी गतिविधियों को DbContext.Database.Log का उपयोग करके लॉग किया जाता है।

आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें एक नया छात्र डेटाबेस में जोड़ा जाता है।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Database.Log = Console.Write;

         // Create a new student and save it

         context.Students.Add(new Student {
            FirstMidName = "Salman", 
            LastName = "Khan", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         context.SaveChanges();
         Console.ReadKey();
      }
   }
}

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

Opened connection at 10/28/2015 6:27:35 PM +05:00
Started transaction at 10/28/2015 6:27:35 PM +05:00
INSERT [dbo].[Student]([LastName], [FirstMidName], [EnrollmentDate])
VALUES (@0, @1, @2)
SELECT [ID]
FROM [dbo].[Student]
WHERE @@ROWCOUNT > 0 AND [ID] = scope_identity()
-- @0: 'Khan' (Type = String, Size = -1)
-- @1: 'Salman' (Type = String, Size = -1)
-- @2: '10/28/2015 12:00:00 AM' (Type = DateTime)
-- Executing at 10/28/2015 6:27:35 PM +05:00
-- Completed in 5 ms with result: SqlDataReader
Committed transaction at 10/28/2015 6:27:35 PM +05:00
Closed connection at 10/28/2015 6:27:35 PM +05:00

जब लॉग प्रॉपर्टी सेट की जाती है तो निम्नलिखित गतिविधियाँ लॉग की जाती हैं -

  • सभी प्रकार के आदेशों के लिए SQL, जैसे कि आवेषण, अद्यतन, और SaveChanges के भाग के रूप में जनरेट किए गए को हटाता है

  • Parameters

  • आदेश को एसिंक्रोनस रूप से निष्पादित किया जा रहा है या नहीं

  • एक टाइमस्टैम्प इंगित करता है जब कमांड निष्पादित करना शुरू कर देता है

  • आदेश सफलतापूर्वक या विफल पूरा हुआ

  • परिणाम मूल्य के कुछ संकेत

  • कमांड निष्पादित करने के लिए अनुमानित समय की मात्रा

दूसरे स्थान पर प्रवेश करना

यदि आपके पास पहले से ही कुछ लॉगिंग ढाँचा है और यह लॉगिंग विधि को परिभाषित करता है तो आप इसे दूसरी जगह भी लॉग इन कर सकते हैं।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें हमारे पास एक और वर्ग MyLogger है।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Database.Log = s ⇒ MyLogger.Log("EFLoggingDemo", s);

         // Create a new student and save it

         context.Students.Add(new Student {
            FirstMidName = "Salman", 
            LastName = "Khan", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         context.SaveChanges();
         Console.ReadKey();
      }
   }
}

public class MyLogger {

   public static void Log(string application, string message) {
      Console.WriteLine("Application: {0}, EF Message: {1} ",application, message);
   }
}

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

एंटिटी फ्रेमवर्क 6.0 में, एक और नई सुविधा है, जिसे जाना जाता है Interceptorया अवरोधन। अवरोधन कोड की अवधारणा के आसपास बनाया गया हैinterception interfaces। उदाहरण के लिए, IDFCommandInterceptor इंटरफ़ेस ईएफ से पहले कॉल करने वाले तरीकों को परिभाषित करता है, ExecuteNonQuery, ExecuteScalar, ExecuteReader, और संबंधित विधियों को कॉल करता है।

  • एंटिटी फ्रेमवर्क इंटरसेप्शन का उपयोग करके वास्तव में चमक सकता है। इस दृष्टिकोण का उपयोग करते हुए आप अपने कोड को अनटाइड किए बिना बहुत अधिक जानकारी को क्षणिक रूप से पकड़ सकते हैं।

  • इसे लागू करने के लिए, आपको अपने स्वयं के कस्टम इंटरसेप्टर बनाने और तदनुसार पंजीकरण करने की आवश्यकता है।

  • एक बार एक वर्ग जो IDbCommandInterceptor इंटरफ़ेस को लागू करता है, उसे DbInterception वर्ग का उपयोग करके एंटिटी फ्रेमवर्क के साथ पंजीकृत किया जा सकता है।

  • IDbCommandInterceptor इंटरफ़ेस में छह विधियाँ हैं और आपको इन सभी विधियों को लागू करने की आवश्यकता है। इन विधियों का मूल कार्यान्वयन निम्नलिखित हैं।

आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें IDbCommandInterceptor इंटरफ़ेस लागू किया गया है।

public class MyCommandInterceptor : IDbCommandInterceptor {

   public static void Log(string comm, string message) {
      Console.WriteLine("Intercepted: {0}, Command Text: {1} ", comm, message);
   }

   public void NonQueryExecuted(DbCommand command, 
      DbCommandInterceptionContext<int> interceptionContext) {
         Log("NonQueryExecuted: ", command.CommandText);
   }

   public void NonQueryExecuting(DbCommand command, 
      DbCommandInterceptionContext<int> interceptionContext) {
         Log("NonQueryExecuting: ", command.CommandText);
   }

   public void ReaderExecuted(DbCommand command, 
      DbCommandInterceptionContext<DbDataReader> interceptionContext) {
         Log("ReaderExecuted: ", command.CommandText);
   }

   public void ReaderExecuting(DbCommand command, 
      DbCommandInterceptionContext<DbDataReader> interceptionContext) {
         Log("ReaderExecuting: ", command.CommandText);
   }

   public void ScalarExecuted(DbCommand command, 
      DbCommandInterceptionContext<object> interceptionContext) {
         Log("ScalarExecuted: ", command.CommandText);
   }

   public void ScalarExecuting(DbCommand command, 
      DbCommandInterceptionContext<object> interceptionContext) {
         Log("ScalarExecuting: ", command.CommandText);
   }

}

इंटरसेप्टर को पंजीकृत करना

एक बार एक वर्ग जो एक या अधिक अवरोधन इंटरफेस का निर्माण करता है, उसे DFInceptionception कक्षा का उपयोग करके EF के साथ पंजीकृत किया जा सकता है जैसा कि निम्नलिखित कोड में दिखाया गया है।

DbInterception.Add(new MyCommandInterceptor());

निम्न कोड में दिखाए गए अनुसार DbConfiguration code- आधारित कॉन्फ़िगरेशन का उपयोग करके इंटरसेप्टर को ऐप-डोमेन स्तर पर भी पंजीकृत किया जा सकता है।

public class MyDBConfiguration : DbConfiguration {

   public MyDBConfiguration() {
      DbInterception.Add(new MyCommandInterceptor());
   }
}

आप कोड का उपयोग करके इंटरसेप्टर कॉन्फिगर फाइल को भी कॉन्फ़िगर कर सकते हैं -

<entityFramework>
   <interceptors>
      <interceptor type = "EFInterceptDemo.MyCommandInterceptor, EFInterceptDemo"/>
   </interceptors>
</entityFramework>

स्थानिक प्रकार का समर्थन एंटिटी फ्रेमवर्क में पेश किया गया था। प्रश्नों के स्थानिक डेटा का विश्लेषण करने के लिए ऑपरेटरों का एक सेट भी शामिल है। उदाहरण के लिए, एक क्वेरी दो भौगोलिक स्थानों के बीच की दूरी के आधार पर फ़िल्टर कर सकती है।

  • एंटिटी फ्रेमवर्क नए स्थानिक डेटा प्रकारों को आपकी कक्षाओं में संपत्तियों के रूप में उजागर करने की अनुमति देगा और उन्हें आपके डेटाबेस में स्थानिक कॉलम में मैप करेगा।

  • आप LINQ क्वेरी को भी लिख पाएंगे जो डेटाबेस में किए गए स्थानिक गणनाओं के आधार पर स्थानिक ऑपरेटरों का उपयोग फ़िल्टर, सॉर्ट और समूह के लिए करते हैं।

दो मुख्य स्थानिक डेटा प्रकार हैं -

  • भूगोल डेटा प्रकार दीर्घवृत्त डेटा को संग्रहीत करता है, उदाहरण के लिए, जीपीएस अक्षांश और देशांतर निर्देशांक।

  • ज्यामिति डेटा प्रकार यूक्लिडियन (फ्लैट) समन्वय प्रणाली का प्रतिनिधित्व करता है।

आइए क्रिकेट मैदान के निम्नलिखित उदाहरण पर एक नज़र डालें।

Step 1 - फ़ाइल → नई → परियोजना मेनू विकल्प से नई परियोजना बनाएँ।

Step 2 - बाएं फलक में, कंसोल एप्लिकेशन चुनें।

Step 3 - प्रोजेक्ट के नाम पर राइट-क्लिक करें और प्रबंधित करें NuGet Package…

Step 4 - एंटिटी फ्रेमवर्क स्थापित करें।

Step 5 - System.Data.Entity असेंबली का संदर्भ जोड़ें और स्थानिक डेटा प्रकारों के लिए विवरण का उपयोग करके System.Data.Spatial भी जोड़ें।

Step 6 - Program.cs फ़ाइल में निम्न वर्ग जोड़ें।

public class CricketGround {
   public int ID { get; set; }
   public string Name { get; set; }
   public DbGeography Location { get; set; }
}

Step 7 - संस्थाओं को परिभाषित करने के अलावा, आपको एक वर्ग को परिभाषित करना होगा जो DbContext से निकलता है और DbSet <TEntity> गुणों को उजागर करता है।

Program.cs में संदर्भ परिभाषा जोड़ें।

public partial class CricketGroundContext : DbContext {
   public DbSet<CricketGround> CricketGrounds { get; set; }
}

Step 8 - मुख्य फ़ंक्शन में निम्नलिखित कोड जोड़ें, जो संदर्भ में दो नए क्रिकेटगॉर्न ऑब्जेक्ट जोड़ देगा।

class Program {

   static void Main(string[] args) {

      using (var context = new CricketGroundContext()) {

         context.CricketGrounds.Add(new CricketGround() {
            Name = "Shalimar Cricket Ground", 
            Location = DbGeography.FromText("POINT(-122.336106 47.605049)"), 
         });

         context.CricketGrounds.Add(new CricketGround() {
            Name = "Marghazar Stadium", Location = DbGeography
               .FromText("POINT(-122.335197 47.646711)"), 
         });

         context.SaveChanges();

         var myLocation = DbGeography.FromText("POINT(-122.296623 47.640405)");

         var cricketGround = (from cg in context.CricketGrounds
            orderby cg.Location.Distance(myLocation) select cg).FirstOrDefault();

         Console.WriteLine("The closest Cricket Ground to you is: {0}.", cricketGround.Name);
      }
   }
}

DbGeography.FromText विधि का उपयोग करके स्थानिक गुणों को प्रारंभ किया जाता है। WellKnownText के रूप में दर्शाए गए भूगोल बिंदु को विधि में पारित किया जाता है और फिर डेटा को सहेजता है। उसके बाद क्रिकेटगॉन्ड ऑब्जेक्ट को पुनः प्राप्त किया जाएगा जहां उसका स्थान निर्दिष्ट स्थान के सबसे करीब है।

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

The closest Cricket Ground to you is: Marghazar Stadium

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

वंशानुक्रम जटिल मॉडल बनाना संभव बनाता है जो बेहतर तरीके से प्रतिबिंबित करते हैं कि डेवलपर्स कैसे सोचते हैं और उन मॉडलों के साथ बातचीत करने के लिए आवश्यक कार्य को भी कम करते हैं। संस्थाओं के साथ उपयोग किया जाने वाला वंशानुक्रम उसी उद्देश्य को पूरा करता है जैसा कि वर्गों के साथ उपयोग किया जाता है, इसलिए डेवलपर्स को पहले से ही यह पता चल जाता है कि यह सुविधा कैसे काम करती है।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें और एक नया कंसोल एप्लिकेशन प्रोजेक्ट बनाकर।

Step 1 - प्रोजेक्ट के नाम पर राइट-क्लिक करके ADO.NET Entity Data Model जोड़ें और Add → New Item… चुनें।

Step 2 - एक मॉडल जोड़ें और अध्याय मॉडल प्रथम दृष्टिकोण में वर्णित सभी चरणों का पालन करके इसे व्यक्ति का नाम दें।

Step 3 - निम्न छवि में दिखाए अनुसार कुछ अदिश गुण जोड़ें।

Step 4 - हम दो और इकाइयाँ जोड़ेंगे Student तथा Teacher, जो व्यक्ति तालिका से गुण वारिस करेगा।

Step 5 - अब छात्र इकाई को जोड़ें और निम्न प्रकार के चित्र में दिखाए अनुसार आधार प्रकार के कॉम्बोक्स से व्यक्ति का चयन करें।

Step 6 - इसी तरह शिक्षक इकाई जोड़ें।

Step 7 - अब एनरोलमेंटडेट स्केलर प्रॉपर्टी को स्टूडेंट एंटिटी और हायरडेट प्रॉपर्टी को टीचर यूनिट में जोड़ें।

Step 8 - चलो आगे बढ़ते हैं और डेटाबेस उत्पन्न करते हैं।

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

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

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

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

Step 13 - आप यह भी देख सकते हैं कि निम्न डोमेन कक्षाएं भी स्वतः उत्पन्न होती हैं।

public partial class Person {
   public int ID { get; set; }
   public string FirstMidName { get; set; }
   public string LastName { get; set; }
}

public partial class Student : Person {
   public System.DateTime EnrollmentDate { get; set; }
}

public partial class Teacher : Person {
   public System.DateTime HireDate { get; set; }
}

निम्नलिखित प्रसंग वर्ग है।

public partial class InheritanceModelContainer : DbContext {

   public InheritanceModelContainer() : 
      base("name = InheritanceModelContainer") {}

   protected override void OnModelCreating(DbModelBuilder modelBuilder) {
      throw new UnintentionalCodeFirstException();
   }

   public virtual DbSet<Person> People { get; set; }
}

आइए डेटाबेस में कुछ छात्रों और शिक्षकों को जोड़ें और फिर इसे डेटाबेस से पुनः प्राप्त करें।

class Program {

   static void Main(string[] args) {

      using (var context = new InheritanceModelContainer()) {

         var student = new Student {
            FirstMidName = "Meredith", 
            LastName = "Alonso", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         };

         context.People.Add(student);

         var student1 = new Student {
            FirstMidName = "Arturo", 
            LastName = "Anand", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         };

         context.People.Add(student1);

         var techaer = new Teacher {
            FirstMidName = "Peggy", 
            LastName = "Justice", 
            HireDate = DateTime.Parse(DateTime.Today.ToString())
         };

         context.People.Add(techaer);

         var techaer1 = new Teacher {
            FirstMidName = "Yan", 
            LastName = "Li", 
            HireDate = DateTime.Parse(DateTime.Today.ToString())
         };

         context.People.Add(techaer1);
         context.SaveChanges();
      }
   }
}

छात्रों और शिक्षकों को डेटाबेस में जोड़ा जाता है। NTo छात्रों और शिक्षक को पुनः प्राप्त करता है,OfType विधि का उपयोग करने की आवश्यकता है, जो निर्दिष्ट विभाग से संबंधित छात्र और शिक्षक को वापस कर देगा।

Console.WriteLine("All students in database"); 
Console.WriteLine("");

foreach (var student in context.People.OfType<Student>()) {
   string name = student.FirstMidName + " " + student.LastName;
   Console.WriteLine("ID: {0}, Name: {1}, \tEnrollment Date {2} ", 
      student.ID, name, student.EnrollmentDate.ToString());
}

Console.WriteLine("");
Console.WriteLine("************************************************************ *****");
Console.WriteLine("");
Console.WriteLine("All teachers in database");
Console.WriteLine("");

foreach (var teacher in context.People.OfType<Teacher>()) {
   string name = teacher.FirstMidName + " " + teacher.LastName;
   Console.WriteLine("ID: {0}, Name: {1}, \tHireDate {2} ", 
      teacher.ID, name, teacher.HireDate.ToString()); 
}

Console.WriteLine("");
Console.WriteLine("************************************************************ *****");
Console.ReadKey();

पहली क्वेरी में, जब आपType <Student> () का उपयोग करते हैं, तब आप HireDate का उपयोग नहीं कर पाएंगे क्योंकि HireDate संपत्ति शिक्षक इकाई का हिस्सा है और इसी तरह EnrolmentDate संपत्ति का उपयोग तब नहीं होगा जब आप Type <Teacher> () का उपयोग करते हैं

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

All students in database
ID: 1, Name: Meredith Alonso,   Enrollment Date 10/30/2015 12:00:00 AM
ID: 2, Name: Arturo Anand,      Enrollment Date 10/30/2015 12:00:00 AM
*****************************************************************  
All teachers in database
ID: 3, Name: Peggy Justice,     HireDate 10/30/2015 12:00:00 AM
ID: 4, Name: Yan Li,    HireDate 10/30/2015 12:00:00 AM
*****************************************************************

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

एंटिटी फ्रेमवर्क 5 और एंटिटी फ्रेमवर्क के पिछले संस्करणों में, कोड को मुख्य पुस्तकालयों (मुख्य रूप से System.Data.Entity.dll) के बीच विभाजित किया गया था। .NET फ्रेमवर्क के हिस्से के रूप में भेज दिया गया था, और अतिरिक्त पुस्तकालयों (मुख्य रूप से EntityFramework.dll) को वितरित और वितरित किया गया था। नुगेट का उपयोग करके शिप किया गया जैसा कि निम्नलिखित चित्र में दिखाया गया है।

एंटिटी फ्रेमवर्क 6 में, कोर एपीआई जो पहले .NET फ्रेमवर्क का हिस्सा थे, को भी नूगेट पैकेज के एक हिस्से के रूप में शिप और वितरित किया जाता है।

एंटिटी फ्रेमवर्क को खुला स्रोत बनाने की अनुमति देने के लिए यह आवश्यक था। हालाँकि, जब भी कोई आवेदन करने की आवश्यकता होगी, तब तक आपके आवेदन को एंटिटी फ्रेमवर्क के पुराने संस्करणों से EF 6 में माइग्रेट या अपग्रेड करने की आवश्यकता होगी।

यदि आपका एप्लिकेशन DFContext का उपयोग करता है, तो माइग्रेशन प्रक्रिया सीधी है, जिसे EF 4.1 और बाद में भेज दिया गया था। लेकिन अगर आपका आवेदन ObjectContext है तो थोड़ा और काम करने की आवश्यकता है।

आइए एक मौजूदा एप्लिकेशन को EF6 में अपग्रेड करने के लिए आपको निम्नलिखित चरणों पर ध्यान देना चाहिए।

Step 1 - पहला कदम .NET फ्रेमवर्क 4.5.2 को लक्षित करना है और बाद में अपनी परियोजना पर राइट क्लिक करें और गुणों का चयन करें।

Step 2 - अपने प्रोजेक्ट पर फिर से राइट क्लिक करें और मैनेज करें एनगेट पैकेज ...

Step 3- ऑनलाइन टैब के तहत EntityFramework चुनें और इंस्टॉल पर क्लिक करें। सुनिश्चित करें कि System.Data.Entity.dll के असेंबली संदर्भ हटा दिए गए हैं।

जब आप EF6 NuGet पैकेज स्थापित करते हैं तो यह आपके लिए आपके प्रोजेक्ट से System.Data.Entity के किसी भी संदर्भ को स्वचालित रूप से हटा देना चाहिए।

Step 4 - यदि आपके पास कोई मॉडल है जो EF डिज़ाइनर के साथ बनाया गया है, तो आपको EFO संगत कोड जेनरेट करने के लिए कोड जेनरेशन टेम्प्लेट को अपडेट करना होगा।

Step 5 - अपने edmx फ़ाइल के अंतर्गत आपके सोल्यूशन एक्सप्लोरर में, मौजूदा कोड-जेनरेशन टेम्प्लेट्स को हटा दें, जिसे आम तौर पर <edmx_file_name> .tt और <edmx_file_name> .Context.tt नाम दिया जाएगा।

Step 6 - EF डिज़ाइनर में अपना मॉडल खोलें, डिज़ाइन की सतह पर राइट क्लिक करें और Add Code Generation Item चुनें ...

Step 7 - उपयुक्त EF 6.x कोड पीढ़ी टेम्पलेट जोड़ें।

यह स्वचालित रूप से EF6 संगत कोड भी उत्पन्न करेगा।

यदि आपके एप्लिकेशन EF 4.1 का उपयोग करते हैं या बाद में आपको कोड में कुछ भी बदलने की आवश्यकता नहीं होगी, क्योंकि DbContext और Code First प्रकारों के नाम स्थान नहीं बदले हैं।

लेकिन यदि आपका एप्लिकेशन एंटिटी फ्रेमवर्क के पुराने संस्करण का उपयोग कर रहा है, तो ObjectContext जैसे प्रकार जो पहले System.Data.Entity.dll में थे, नए नामस्थानों में स्थानांतरित कर दिए गए हैं।

Step 8 - आपको ईएफ 6 के खिलाफ निर्माण के लिए अपने उपयोग या आयात निर्देशों को अपडेट करने की आवश्यकता होगी।

नाम स्थान परिवर्तन के लिए सामान्य नियम यह है कि System.Data में किसी भी प्रकार। उनमें से कुछ निम्नलिखित हैं -

  • System.Data.EntityException ⇒ System.Data.Entity.Core.EntityException
  • System.Data.Objects.ObjectContext ⇒ System.Data.Entity.Core.Objects.ObjectContext;
  • System.Data.Objects.DataClasses.RelationshipManager ⇒ System.Data.Entity.Core.Objects.DataClasses.RelationshipManager;

कोर नेमस्पेस में कुछ प्रकार होते हैं, क्योंकि वे सीधे अधिकांश DbContext- आधारित अनुप्रयोगों के लिए उपयोग नहीं किए जाते हैं।

  • System.Data.EntityState ⇒ System.Data.Entity.EntityState
  • System.Data.Objects.DataClasses.EdmFunctionAttribute ⇒ System.Data.Entity.DbFunctionAttribute

आपका मौजूदा एंटिटी फ्रेमवर्क प्रोजेक्ट बिना किसी बड़े बदलाव के एंटिटी फ्रेमवर्क 6.0 में काम करेगा।

एगर लोडिंग एक ऐसी प्रक्रिया है, जिसमें एक प्रकार की इकाई के लिए एक क्वेरी भी संबंधित संस्थाओं को क्वेरी के हिस्से के रूप में लोड करती है। ईगर लोडिंग के उपयोग से प्राप्त किया जाता है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();

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

आलसी लोडिंग एक ऐसी प्रक्रिया है जिसके तहत किसी संस्था या संस्थाओं के संग्रह को स्वचालित रूप से पहली बार डेटाबेस से लोड किया जाता है, जो कि इकाई / संस्थाओं का जिक्र करने वाली संपत्ति तक पहुँचा जाता है। आलसी लोडिंग का अर्थ है संबंधित डेटा को लोड करने में देरी करना, जब तक कि आप इसके लिए विशेष रूप से अनुरोध न करें।

  • 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

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

जब आपने आलसी लोडिंग को अक्षम कर दिया, तो संबंधित संस्थाओं को लोड करना अभी भी संभव है, लेकिन यह एक स्पष्ट कॉल के साथ किया जाना चाहिए।

  • आलसी लोडिंग के विपरीत, क्वेरी चलने पर कोई अस्पष्टता या भ्रम की संभावना नहीं है।

  • ऐसा करने के लिए आप संबंधित इकाई के प्रवेश पर लोड विधि का उपयोग करते हैं।

  • एक-से-कई संबंधों के लिए, संग्रह पर लोड विधि को कॉल करें।

  • और एक-से-एक संबंध के लिए, संदर्भ पर लोड विधि को कॉल करें।

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

छात्र की जानकारी तब कंसोल पर लिखी जाती है। यदि आप कोड को देखते हैं, तो नामांकन जानकारी भी लिखी जाती है, लेकिन नामांकन संस्था को अभी तक लोड नहीं किया गया है, इसलिए फ़ॉरच लूप निष्पादित नहीं किया जाएगा।

उसके बाद नामांकन संस्था स्पष्ट रूप से भरी हुई है, अब छात्र जानकारी और नामांकन जानकारी कंसोल विंडो पर लिखी जाएगी।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Configuration.LazyLoadingEnabled = false;

         var student = (from s in context.Students where s.FirstMidName == 
            "Ali" select s).FirstOrDefault<Student>();

         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.WriteLine();
         Console.WriteLine("Explicitly loaded Enrollments");
         Console.WriteLine();

         context.Entry(student).Collection(s ⇒ s.Enrollments).Load();
         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
Explicitly loaded Enrollments
ID: 1, Name: Ali Alexander
       Enrollment ID: 1, Course ID: 1050
       Enrollment ID: 2, Course ID: 4022
       Enrollment ID: 3, Course ID: 4041

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

इस अध्याय में आइए हम उन मान्य तकनीकों के बारे में जानें, जिनका उपयोग ADO.NET इकाई ढांचे में मॉडल डेटा को मान्य करने के लिए किया जा सकता है। एंटिटी फ्रेमवर्क कई प्रकार के सत्यापन सुविधाएँ प्रदान करता है जिन्हें क्लाइंट-साइड सत्यापन के लिए उपयोगकर्ता इंटरफ़ेस पर लागू किया जा सकता है या सर्वर-साइड सत्यापन के लिए उपयोग किया जा सकता है।

  • एंटिटी फ्रेमवर्क में, डेटा सत्यापन किसी एप्लिकेशन में खराब डेटा को पकड़ने के लिए समाधान का हिस्सा है।

  • डेटा फ्रेमवर्क विधियों की एक विस्तृत श्रृंखला का उपयोग करके डेटाबेस द्वारा डिफ़ॉल्ट रूप से लिखे जाने से पहले, एंटिटी फ्रेमवर्क सभी डेटा को मान्य करता है।

  • हालाँकि, उपयोगकर्ता-इंटरफ़ेस डेटा सत्यापन के बाद Entity फ्रेमवर्क आता है। तो उस मामले में ईएफ फेंकता है और एक सामान्य संदेश दिखाने के लिए किसी भी अपवाद को संभालने के लिए इकाई सत्यापन की आवश्यकता है।

  • आपकी त्रुटि जाँच और उपयोगकर्ता को वापस त्रुटि संदेश पास करने के लिए डेटा सत्यापन की कुछ तकनीकें हैं।

DbContext में ValidateEntity नाम का एक ओवरराइडेबल तरीका है। जब आप SaveChanges को कॉल करते हैं, तो Entity Framework अपने कैश में प्रत्येक इकाई के लिए इस पद्धति को कॉल करेगा जिसकी स्थिति अपरिवर्तित नहीं है। आप छात्र तर्क के लिए निम्न उदाहरण में सीधे सत्यापन तर्क यहाँ रख सकते हैं।

public partial class UniContextEntities : DbContext {

   protected override System.Data.Entity.Validation
      .DbEntityValidationResult ValidateEntity(DbEntityEntry entityEntry, 
      System.Collections.Generic.IDictionary<object, object> items) {

         if (entityEntry.Entity is Student) {

            if (entityEntry.CurrentValues.GetValue<string>("FirstMidName") == "") {

               var list = new List<System.Data.Entity
                  .Validation.DbValidationError>();

               list.Add(new System.Data.Entity.Validation
                  .DbValidationError("FirstMidName", "FirstMidName is required"));

               return new System.Data.Entity.Validation
                  .DbEntityValidationResult(entityEntry, list);
            }
         }

         if (entityEntry.CurrentValues.GetValue<string>("LastName") == "") {

            var list = new List<System.Data.Entity
               .Validation.DbValidationError>();

            list.Add(new System.Data.Entity.Validation
               .DbValidationError("LastName", "LastName is required"));

            return new System.Data.Entity.Validation
               .DbEntityValidationResult(entityEntry, list);
         }

         return base.ValidateEntity(entityEntry, items);
   }
}

उपरोक्त मान्य विधि, छात्र इकाई FirstMidName और LastName गुणों की जाँच की जाती है यदि इनमें से किसी भी संपत्ति में एक खाली स्ट्रिंग है, तो यह एक त्रुटि संदेश लौटाएगा।

आइए एक सरल उदाहरण देखें जिसमें एक नया छात्र बनाया गया है, लेकिन छात्र का फर्स्टमीडनाम खाली स्ट्रिंग है जैसा कि निम्नलिखित कोड में दिखाया गया है।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         Console.WriteLine("Adding new Student to the database");
         Console.WriteLine();

         try {

            context.Students.Add(new Student() {
               FirstMidName = "",
               LastName = "Upston"
            });

            context.SaveChanges();
         } catch (DbEntityValidationException dbValidationEx) {

            foreach (DbEntityValidationResult entityErr in 
               dbValidationEx.EntityValidationErrors) {

               foreach (DbValidationError error in entityErr.ValidationErrors) {
                  Console.WriteLine("Error: {0}",error.ErrorMessage);
               }
            }
         }

         Console.ReadKey();
      }
   }
}

जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है, तो आपको कंसोल विंडो पर निम्न त्रुटि संदेश प्राप्त होगा।

Adding new Student to the database  
Error: FirstMidName is required

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

एंटिटी फ्रेमवर्क संस्थाओं और उनके संबंधों के लिए किए गए परिवर्तनों को ट्रैक करने की क्षमता प्रदान करता है, इसलिए डेटाबेस के संदर्भ में SaveChanges विधि कहा जाता है, तो सही अद्यतन किए जाते हैं। यह एंटिटी फ्रेमवर्क की एक प्रमुख विशेषता है।

  • परिवर्तन ट्रैकिंग ट्रैक इकाई संग्रह में नए रिकॉर्ड (ओं) को जोड़ते हुए परिवर्तन करता है, मौजूदा संस्थाओं को संशोधित या हटाता है।

  • फिर सभी परिवर्तन DbContext स्तर द्वारा रखे जाते हैं।

  • DbContext ऑब्जेक्ट के नष्ट होने से पहले सहेजे नहीं जाने पर ये ट्रैक परिवर्तन खो जाते हैं।

  • DbChangeTracker वर्ग आपको संदर्भ द्वारा ट्रैक की जा रही वर्तमान संस्थाओं के बारे में सभी जानकारी देता है।

  • किसी भी इकाई को संदर्भ द्वारा ट्रैक करने के लिए, उसके पास प्राथमिक कुंजी गुण होना चाहिए।

एंटिटी फ्रेमवर्क में, डिफ़ॉल्ट रूप से परिवर्तन ट्रैकिंग सक्षम है। आप DbContext की AutoDetectChangesEnabled संपत्ति को गलत पर सेट करके परिवर्तन ट्रैकिंग को अक्षम कर सकते हैं। यदि यह संपत्ति सही है, तो एंटिटी फ्रेमवर्क संस्थाओं की स्थिति को बनाए रखता है।

using (var context = new UniContextEntities()) {
   context.Configuration.AutoDetectChangesEnabled = true;
}

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें छात्रों और उनके नामांकन डेटाबेस से पुनर्प्राप्त किए जाते हैं।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Configuration.AutoDetectChangesEnabled = true;
         Console.WriteLine("Retrieve Student");

         var student = (from s in context.Students where s.FirstMidName == 
            "Ali" select s).FirstOrDefault<Student>();

         string name = student.FirstMidName + " " + student.LastName;
         Console.WriteLine("ID: {0}, Name: {1}", student.ID, name);
         Console.WriteLine();
         Console.WriteLine("Retrieve all related enrollments");

         foreach (var enrollment in student.Enrollments) {
            Console.WriteLine("Enrollment ID: {0}, Course ID: {1}", 
               enrollment.EnrollmentID, enrollment.CourseID);
         }

         Console.WriteLine();

         Console.WriteLine("Context tracking changes of {0} entity.", 
            context.ChangeTracker.Entries().Count());

         var entries = context.ChangeTracker.Entries();

         foreach (var entry in entries) {
            Console.WriteLine("Entity Name: {0}", entry.Entity.GetType().Name);
            Console.WriteLine("Status: {0}", entry.State);
         }

         Console.ReadKey();
      }
   }
}

जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है तो आपको निम्न आउटपुट प्राप्त होगा।

Retrieve Student 
ID: 1, Name: Ali Alexander
Retrieve all related enrollments
       Enrollment ID: 1, Course ID: 1050
       Enrollment ID: 2, Course ID: 4022
       Enrollment ID: 3, Course ID: 4041
Context tracking changes of 4 entity.
Entity Name: Student
Status: Unchanged
Entity Name: Enrollment
Status: Unchanged
Entity Name: Enrollment
Status: Unchanged
Entity Name: Enrollment
Status: Unchanged

आप देख सकते हैं कि सभी डेटा केवल डेटाबेस से पुनर्प्राप्त किए गए हैं, इसीलिए सभी संस्थाओं के लिए स्थिति अपरिवर्तित है।

आइए अब एक और सरल उदाहरण देखें, जिसमें हम एक और नामांकन जोड़ेंगे और एक छात्र को डेटाबेस से हटा देंगे। निम्नलिखित वह कोड है जिसमें नया नामांकन जोड़ा जाता है और एक छात्र को हटा दिया जाता है।

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Configuration.AutoDetectChangesEnabled = true;

         Enrollment enr = new Enrollment() { 
            StudentID = 1, CourseID = 3141 
         };

         Console.WriteLine("Adding New Enrollment");
         context.Enrollments.Add(enr);
         Console.WriteLine("Delete Student");

         var student = (from s in context.Students where s.ID == 
            23 select s).SingleOrDefault<Student>();

         context.Students.Remove(student);
         Console.WriteLine("");

         Console.WriteLine("Context tracking changes of {0} entity.", 
            context.ChangeTracker.Entries().Count());
         var entries = context.ChangeTracker.Entries();

         foreach (var entry in entries) {
            Console.WriteLine("Entity Name: {0}", entry.Entity.GetType().Name);
            Console.WriteLine("Status: {0}", entry.State);
         }

         Console.ReadKey();
      }
   }
}

जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा।

Adding New Enrollment
Delete Student
Context tracking changes of 2 entity.
Entity Name: Enrollment
Status: Added
Entity Name: Student
Status: Deleted

अब आप देख सकते हैं कि नामांकन इकाई की स्थिति को जोड़ा गया है, और छात्र इकाई की स्थिति को हटा दिया गया है, क्योंकि नया नामांकन जोड़ा गया है और एक छात्र को डेटाबेस से हटा दिया गया है।

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

एंटिटी फ्रेमवर्क में, रंगीन एंटिटी मुख्य रूप से डिजाइनर में इकाई के रंग को बदलने के बारे में है ताकि डेवलपर्स के लिए विजुअल स्टूडियो डिजाइनर में संबंधित समूहों की पहचान करना आसान हो। इस फीचर को सबसे पहले एंटिटी फ्रेमवर्क 5.0 में पेश किया गया था।

  • इस सुविधा का प्रदर्शन पहलुओं से कोई लेना-देना नहीं है।

  • जब आपके पास एक edmx फ़ाइल में बड़े पैमाने पर प्रोजेक्ट और कई इकाइयाँ होती हैं, तो यह सुविधा अलग-अलग मॉड्यूल में आपकी संस्थाओं को अलग करने के लिए बहुत सहायक होती है।

यदि आप edmx फ़ाइल के साथ काम कर रहे हैं और आपने इसे डिज़ाइनर में खोला है, तो रंग बदलने के लिए, डिज़ाइन विंडो पर एक इकाई चुनें। इसके बाद राइट क्लिक करें और प्रॉपर्टीज चुनें।

गुण विंडो में, रंग गुण भरें का चयन करें।

या तो मान्य रंग नाम का उपयोग करके रंग निर्दिष्ट करें, उदाहरण के लिए, ग्रीन या एक मान्य RGB (255, 128, 128) या आप रंग बीनने वाले से भी चयन कर सकते हैं।

एक बार में कई संस्थाओं का रंग बदलने के लिए, कई संस्थाओं का चयन करें और संपत्ति विंडो का उपयोग करके उन सभी के लिए रंग भरें।

आप निम्न विकल्पों में से किसी का भी चयन करके गुणों के प्रारूप को बदल सकते हैं -

  • प्रदर्शित होने वाला नाम
  • नाम और प्रकार प्रदर्शित करें

डिफ़ॉल्ट रूप से, प्रदर्शन नाम विकल्प चुना जाता है। संपत्ति प्रारूप को बदलने के लिए, डिजाइनर विंडो पर राइट-क्लिक करें।

स्केलर प्रॉपर्टी फॉर्मेट → प्रदर्शन नाम और प्रकार का चयन करें।

अब आप देख सकते हैं कि नाम के साथ प्रकार भी प्रदर्शित किया गया है।

एंटिटी फ्रेमवर्क एक इकाई मॉडल बनाने के लिए तीन दृष्टिकोण प्रदान करता है और हर एक के अपने पेशेवरों और विपक्ष हैं।

  • कोड प्रथम
  • डेटाबेस पहले
  • मॉडल प्रथम

इस अध्याय में, हम कोड पहले दृष्टिकोण का संक्षेप में वर्णन करेंगे। कुछ डेवलपर्स कोड में डिजाइनर के साथ काम करना पसंद करते हैं, जबकि अन्य केवल अपने कोड के साथ काम करना पसंद करेंगे। उन डेवलपर्स के लिए, एंटिटी फ्रेमवर्क में एक मॉडलिंग वर्कफ़्लो है जिसे कोड फ़र्स्ट कहा जाता है।

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

  • इसका उपयोग तब भी किया जा सकता है जब आपके पास एक खाली डेटाबेस हो और फिर कोड फर्स्ट इसमें नई तालिकाएँ जोड़ देगा।

  • कोड पहले आपको C # या VB.Net कक्षाओं का उपयोग करके अपने मॉडल को परिभाषित करने की अनुमति देता है।

  • अतिरिक्त कॉन्फ़िगरेशन वैकल्पिक रूप से आपकी कक्षाओं और संपत्तियों पर विशेषताओं का उपयोग करके या धाराप्रवाह एपीआई का उपयोग करके किया जा सकता है।

कोड पहले क्यों?

  • कोड फर्स्ट वास्तव में पहेली टुकड़ों के समूह से बना है। पहले आपकी डोमेन कक्षाएं हैं।

  • डोमेन कक्षाओं का एंटिटी फ्रेमवर्क से कोई लेना-देना नहीं है। वे आपके व्यवसाय डोमेन के आइटम हैं।

  • एंटिटी फ्रेमवर्क, का एक संदर्भ है, जो उन वर्गों और आपके डेटाबेस के बीच बातचीत का प्रबंधन करता है।

  • संदर्भ कोड प्रथम के लिए विशिष्ट नहीं है। यह एक एंटिटी फ्रेमवर्क फीचर है।

  • कोड फर्स्ट एक मॉडल बिल्डर को जोड़ता है जो आपकी कक्षाओं का निरीक्षण करता है कि संदर्भ प्रबंध कर रहा है, और फिर यह निर्धारित करने के लिए नियमों या सम्मेलनों का एक सेट का उपयोग करता है कि कैसे उन वर्गों और रिश्तों का एक मॉडल वर्णन करता है, और उस मॉडल को आपके डेटाबेस में कैसे मैप करना चाहिए।

  • यह सब रनटाइम पर होता है। आप इस मॉडल को कभी नहीं देख पाएंगे, यह सिर्फ स्मृति में है।

  • यदि आप चाहते हैं तो कोड फर्स्ट में उस मॉडल का उपयोग करने के लिए डेटाबेस बनाने की क्षमता भी है।

  • कोड फर्स्ट माइग्रेशन नामक सुविधा का उपयोग करके, यदि मॉडल बदलता है तो यह डेटाबेस को अपडेट भी कर सकता है।

पर्यावरण सेटअप

ईएफ कोड पहले दृष्टिकोण के साथ काम करना शुरू करने के लिए आपको अपने सिस्टम पर निम्नलिखित टूल की आवश्यकता है।

  • विजुअल स्टूडियो 2013 (.net फ्रेमवर्क 4.5.2) या बाद का संस्करण।
  • MS SQL सर्वर 2012 या बाद का।
  • NuGet पैकेज के माध्यम से एंटिटी फ्रेमवर्क।

NuGet पैकेज के माध्यम से EF स्थापित करें

Step 1 - सबसे पहले, फ़ाइल → नया → प्रोजेक्ट से कंसोल एप्लिकेशन बनाएं ...

Step 2 - टेम्पलेट फलक से बाएं फलक और कंसोल एप्लिकेशन से विंडोज का चयन करें।

Step 3 - नाम के रूप में EFCodeFirstDemo दर्ज करें और ठीक चुनें।

Step 4 - समाधान एक्सप्लोरर में अपनी परियोजना पर राइट-क्लिक करें और प्रबंधित करें NuGet पैकेज…

यह NuGet पैकेज मैनेजर खोलेगा, और EntityFramework की खोज करेगा। यह एंटिटी फ्रेमवर्क से संबंधित सभी पैकेजों की खोज करेगा।

Step 5- EntityFramework चुनें और इंस्टॉल पर क्लिक करें। या टूल मेनू से NuGet Package Manager पर क्लिक करें और फिर पैकेज मैनेजर कंसोल पर क्लिक करें। पैकेज प्रबंधक कंसोल विंडो में, निम्न कमांड दर्ज करें: इंस्टाल-पैकेज EntityFramework।

जब स्थापना पूरी हो जाती है, तो आपको आउटपुट विंडो में निम्न संदेश दिखाई देगा "सफलतापूर्वक EFCodeFirstDemo को 'EntityFramework 6.1.2' स्थापित किया गया है।"

स्थापना के बाद, EntityFramework.dll आपकी परियोजना में शामिल किया जाएगा, जैसा कि निम्नलिखित छवि में दिखाया गया है।

अब आप कोड प्रथम दृष्टिकोण पर काम करना शुरू करने के लिए तैयार हैं।

कक्षाओं का उपयोग करते हुए एक बहुत ही सरल मॉडल को परिभाषित करते हैं। हम उन्हें सिर्फ Program.cs फ़ाइल में परिभाषित कर रहे हैं, लेकिन एक वास्तविक दुनिया के अनुप्रयोग में आप अपनी कक्षाओं को अलग-अलग फ़ाइलों और संभवतः एक अलग प्रोजेक्ट में विभाजित करेंगे। निम्नलिखित एक डेटा मॉडल है जिसे हम कोड प्रथम दृष्टिकोण का उपयोग करके बना रहे हैं।

मॉडल बनाएं

छात्र वर्ग के लिए निम्नलिखित कोड का उपयोग करके Program.cs फ़ाइल में निम्न तीन कक्षाएं जोड़ें।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}
  • ID गुण डेटाबेस तालिका का प्राथमिक कुंजी स्तंभ बन जाएगा जो इस वर्ग से मेल खाता है।

  • नामांकन संपत्ति एक नेविगेशन संपत्ति है। नेविगेशन गुण अन्य संस्थाएं हैं जो इस इकाई से संबंधित हैं।

  • इस स्थिति में, एक छात्र इकाई की नामांकन संपत्ति उस छात्र इकाई से संबंधित सभी नामांकन संस्थाएं रखेगी।

  • नेविगेशन गुणों को आमतौर पर वर्चुअल के रूप में परिभाषित किया जाता है ताकि वे कुछ एंटिटी फ्रेमवर्क कार्यक्षमता जैसे आलसी लोडिंग का लाभ उठा सकें।

  • यदि एक नेविगेशन संपत्ति कई संस्थाओं (जैसे कई-से-कई या एक-टोमनी रिश्तों में) को धारण कर सकती है, तो इसका प्रकार एक सूची होना चाहिए जिसमें प्रविष्टियों को जोड़ा, हटाया, और अद्यतन किया जा सकता है, जैसे कि ICollection।

निम्नलिखित पाठ्यक्रम वर्ग के लिए कार्यान्वयन है।

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

नामांकन संपत्ति एक नेविगेशन संपत्ति है। एक कोर्स इकाई किसी भी संख्या में नामांकन संस्थाओं से संबंधित हो सकती है।

निम्नलिखित नामांकन वर्ग और एनम के लिए कार्यान्वयन है।

public enum Grade {
   A, B, C, D, F
}

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }
}
  • एनरोलमेंटआईडी संपत्ति प्राथमिक कुंजी होगी।

  • ग्रेड संपत्ति एक एनम है। ग्रेड प्रकार की घोषणा के बाद प्रश्न चिह्न इंगित करता है कि ग्रेड संपत्ति अशक्त है।

  • एक ग्रेड जो शून्य है वह एक शून्य ग्रेड से अलग है। नल का मतलब है कि एक ग्रेड ज्ञात नहीं है या अभी तक असाइन नहीं किया गया है।

  • स्टूडेंट और कोर्सिड प्रॉपर्टीज विदेशी चाबियां हैं, और संबंधित नेविगेशन प्रॉपर्टीज स्टूडेंट और कोर्स हैं।

  • एक नामांकन इकाई एक छात्र और एक पाठ्यक्रम इकाई से जुड़ी होती है, इसलिए संपत्ति केवल एक छात्र और पाठ्यक्रम इकाई रख सकती है।

डेटाबेस संदर्भ बनाएँ

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

public class MyContext : DbContext {
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

Program.cs फ़ाइल में पूर्ण कोड निम्नलिखित है।

using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace EFCodeFirstDemo {

   class Program {
      static void Main(string[] args) {}
   }

   public enum Grade {
      A, B, C, D, F
   }

   public class Enrollment {
      public int EnrollmentID { get; set; }
      public int CourseID { get; set; }
      public int StudentID { get; set; }
      public Grade? Grade { get; set; }
		
      public virtual Course Course { get; set; }
      public virtual Student Student { get; set; }
   }

   public class Student {
      public int ID { get; set; }
      public string LastName { get; set; }
      public string FirstMidName { get; set; }
      public DateTime EnrollmentDate { get; set; }
		
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }

   public class Course {
      public int CourseID { get; set; }
      public string Title { get; set; }
      public int Credits { get; set; }
		
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }

   public class MyContext : DbContext {
      public virtual DbSet<Course> Courses { get; set; }
      public virtual DbSet<Enrollment> Enrollments { get; set; }
      public virtual DbSet<Student> Students { get; set; }
   }

}

उपरोक्त कोड हम सभी को डेटा संग्रहीत करने और पुनर्प्राप्त करने की आवश्यकता है। आइए कुछ डेटा जोड़ें और फिर इसे पुनः प्राप्त करें। निम्नलिखित मुख्य विधि में कोड है।

static void Main(string[] args) {

   using (var context = new MyContext()) {
      // Create and save a new Students
      Console.WriteLine("Adding new students");

      var student = new Student {
         FirstMidName = "Alain", LastName = "Bomer", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      };

      context.Students.Add(student);
		
      var student1 = new Student {
         FirstMidName = "Mark", LastName = "Upston", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      };

      context.Students.Add(student1);
      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.WriteLine("Press any key to exit...");
      Console.ReadKey();
   }
}

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

Adding new students
Retrieve all Students from the database:
ID: 1, Name: Alain Bomer
ID: 2, Name: Mark Upston
Press any key to exit...

अब जो सवाल दिमाग में आता है वह है डेटा और डेटाबेस जिसमें हमने कुछ डेटा जोड़े हैं और फिर इसे डेटाबेस से पुनर्प्राप्त किया है। सम्मेलन द्वारा, DbContext ने आपके लिए एक डेटाबेस बनाया है।

  • यदि कोई स्थानीय SQL एक्सप्रेस उदाहरण उपलब्ध है, तो कोड पहले ने उस उदाहरण पर डेटाबेस बनाया है।

  • यदि SQL Express उपलब्ध नहीं है, तो कोड फर्स्ट LocalDb का उपयोग करने का प्रयास करेगा।

  • डेटाबेस का नाम व्युत्पन्न संदर्भ के पूरी तरह से योग्य नाम के बाद रखा गया है।

हमारे मामले में, SQL एक्सप्रेस उदाहरण उपलब्ध है, और डेटाबेस का नाम EFCodeFirstDemo.MyContext है जैसा कि निम्नलिखित छवि में दिखाया गया है।

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

  • जैसा कि आप ऊपर की छवि में देख सकते हैं, इसने छात्रों, पाठ्यक्रम और नामांकन तालिकाएँ बनाई हैं और प्रत्येक तालिका में उपयुक्त डेटाटाइप और लंबाई वाले कॉलम हैं।

  • कॉलम नाम और डेटाटाइप भी संबंधित डोमेन कक्षाओं के गुणों से मेल खाते हैं।

डेटाबेस इनिशियलाइज़ेशन

उपरोक्त उदाहरण में, हमने देखा है कि कोड फर्स्ट स्वचालित रूप से एक डेटाबेस बनाता है, लेकिन यदि आप डेटाबेस और सर्वर का नाम बदलना चाहते हैं, तो आइए देखते हैं कि कैसे कोड फर्स्ट डेटाबेस को शुरू करते समय डेटाबेस का नाम और सर्वर तय करता है। निम्नलिखित आरेख पर एक नज़र डालें।

आप निम्न तरीकों से संदर्भ वर्ग के आधार निर्माता को परिभाषित कर सकते हैं।

  • कोई पैरामीटर नहीं
  • डेटाबेस नाम
  • कनेक्शन स्ट्रिंग नाम

कोई पैरामीटर नहीं

यदि आप उपरोक्त उदाहरण में दिखाए गए अनुसार किसी भी पैरामीटर के बिना संदर्भ वर्ग के बेस कंस्ट्रक्टर को निर्दिष्ट करते हैं, तो इकाई रूपरेखा आपके स्थानीय SQLEXPRESS सर्वर में {Namespace} नाम {Context class name} नाम से एक डेटाबेस बनाएगी।

उपरोक्त उदाहरण में, जो डेटाबेस स्वचालित रूप से बनाया गया है उसका नाम EFCodeFirstDemo.MyContext है। यदि आप नाम देखेंगे, तो आप पाएंगे कि EFCodeFirstDemo नाम स्थान है और MyContext संदर्भ वर्ग का नाम है जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class MyContext : DbContext {
   public MyContext() : base() {}

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

डेटाबेस नाम

यदि आप संदर्भ वर्ग के बेस कंस्ट्रक्टर में एक पैरामीटर के रूप में डेटाबेस का नाम पास करते हैं, तो कोड फर्स्ट फिर से स्वचालित रूप से एक डेटाबेस बनाएगा, लेकिन इस बार नाम स्थानीय SQLEXPRESS डेटाबेस सर्वर पर बेस कंस्ट्रक्टर में पैरामीटर के रूप में पारित किया जाएगा। ।

निम्नलिखित कोड में, MyContextDB को बेस कंस्ट्रक्टर में पैरामीटर के रूप में निर्दिष्ट किया गया है। यदि आप अपना एप्लिकेशन चलाते हैं, तो MyContextDB नाम वाला डेटाबेस आपके स्थानीय SQL सर्वर में बनाया जाएगा।

public class MyContext : DbContext {
   public MyContext() : base("MyContextDB") {}
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

कनेक्शन स्ट्रिंग नाम

यह DbContext को SQL Express या LocalDb के अलावा किसी डेटाबेस सर्वर का उपयोग करने का एक आसान तरीका है। आप अपनी ऐप में एक कनेक्शन स्ट्रिंग रखना चुन सकते हैं। फाइल फाइल।

  • यदि कनेक्शन स्ट्रिंग का नाम आपके संदर्भ के नाम से मेल खाता है (या तो नामस्थान योग्यता के साथ या बिना), तो यह DbContext द्वारा पाया जाएगा जब पैरामीटर कम कंस्ट्रक्टर का उपयोग किया जाता है।

  • यदि कनेक्शन स्ट्रिंग नाम आपके संदर्भ के नाम से अलग है, तो आप DbContext कंस्ट्रक्टर को कनेक्शन स्ट्रिंग नाम पास करके कोड फर्स्ट मोड में इस कनेक्शन का उपयोग करने के लिए कह सकते हैं।

public class MyContext : DbContext {
   public MyContext() : base("name = MyContextDB") {}
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}
  • उपरोक्त कोड में, बेस कंस्ट्रक्टर में एक पैरामीटर के रूप में संदर्भ वर्ग कनेक्शन स्ट्रिंग का स्निपेट निर्दिष्ट किया गया है।

  • कनेक्शन स्ट्रिंग नाम "नाम =" से शुरू होना चाहिए अन्यथा, यह एक डेटाबेस नाम के रूप में विचार करेगा।

  • यह फ़ॉर्म यह स्पष्ट करता है कि आप अपनी स्ट्रिंग फ़ाइल में कनेक्शन स्ट्रिंग के मिलने की उम्मीद करते हैं। एक अपवाद दिया जाएगा यदि दिए गए नाम के साथ एक कनेक्शन स्ट्रिंग नहीं मिला।

<connectionStrings>
   <add name = "MyContextDB"
      connectionString = "Data Source =.;Initial Catalog = EFMyContextDB;Integrated Security = true"
      providerName = "System.Data.SqlClient"/>
</connectionStrings>
  • App.config में कनेक्शन स्ट्रिंग में डेटाबेस का नाम है EFMyContextDB। CodeFirst एक नया निर्माण करेगाEFMyContextDB डेटाबेस या मौजूदा का उपयोग करें EFMyContextDB स्थानीय SQL सर्वर पर डेटाबेस।

डोमेन कक्षाएं

अब तक हमने EF को अपने डिफ़ॉल्ट सम्मेलनों का उपयोग करके मॉडल की खोज करने दिया है, लेकिन कई बार ऐसा भी होता है जब हमारी कक्षाएं सम्मेलनों का पालन नहीं करती हैं और हमें आगे कॉन्फ़िगरेशन करने में सक्षम होने की आवश्यकता होती है। लेकिन आप अपनी आवश्यकताओं की जानकारी के साथ ईएफ प्रदान करने के लिए अपने डोमेन कक्षाओं को कॉन्फ़िगर करके इन सम्मेलनों को ओवरराइड कर सकते हैं। आपके डोमेन वर्गों को कॉन्फ़िगर करने के लिए दो विकल्प हैं -

  • डेटा एनोटेशन
  • धाराप्रवाह एपीआई

डेटा एनोटेशन

DataAnnotations का उपयोग आपकी कक्षाओं को कॉन्फ़िगर करने के लिए किया जाता है जो सबसे अधिक आवश्यक कॉन्फ़िगरेशन को उजागर करेगा। DataAnnotations को ASP.NET MVC जैसे .NET अनुप्रयोगों की संख्या से भी समझा जाता है, जो इन अनुप्रयोगों को क्लाइंट-साइड सत्यापन के लिए समान एनोटेशन का लाभ उठाने की अनुमति देते हैं।

छात्र वर्ग में उपयोग किए जाने वाले डेटा एनोटेशन निम्नलिखित हैं।

public class Enrollment {

   [Key]
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }

   [ForeignKey("CourseID")]
   public virtual Course Course { get; set; }

   [ForeignKey("ID")]
   public virtual Student Student { get; set; }
}

धाराप्रवाह एपीआई

अधिकांश मॉडल कॉन्फ़िगरेशन को सरल डेटा एनोटेशन का उपयोग करके किया जा सकता है। धाराप्रवाह एपीआई मॉडल कॉन्फ़िगरेशन को निर्दिष्ट करने का एक उन्नत तरीका है जो डेटा एनोटेशन के साथ संभव नहीं होने वाले कुछ और उन्नत कॉन्फ़िगरेशन के अलावा, डेटा एनोटेशन को कवर कर सकता है। डेटा एनोटेशन और धाराप्रवाह एपीआई का एक साथ उपयोग किया जा सकता है।

धाराप्रवाह एपीआई तक पहुँचने के लिए आप DbContext में OnModelCreating विधि को ओवरराइड करते हैं। अब FirstMidName से FirstName तक छात्र तालिका में कॉलम का नाम बदलें जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class MyContext : DbContext {

   protected override void OnModelCreating(DbModelBuilder modelBuilder) {
      modelBuilder.Entity<Student>().Property(s ⇒ s.FirstMidName)
         .HasColumnName("FirstName");
   }

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

DataAnnotations का उपयोग उन वर्गों को कॉन्फ़िगर करने के लिए किया जाता है जो सबसे अधिक आवश्यक कॉन्फ़िगरेशन को उजागर करेंगे। DataAnnotations को ASP.NET MVC जैसे .NET अनुप्रयोगों की एक संख्या द्वारा भी समझा जाता है, जो इन अनुप्रयोगों को क्लाइंट-साइड सत्यापन के लिए समान एनोटेशन का लाभ उठाने की अनुमति देता है। DataAnnotation विशेषताएँ डिफ़ॉल्ट कोडफ़र्स्ट सम्मेलनों को ओवरराइड करती हैं।

System.ComponentModel.DataAnnotations निम्न विशेषताएँ शामिल हैं जो स्तंभ की अशक्तता या आकार को प्रभावित करती हैं।

  • Key
  • Timestamp
  • ConcurrencyCheck
  • Required
  • MinLength
  • MaxLength
  • StringLength

System.ComponentModel.DataAnnotations.Schema namepace में डेटाबेस के स्कीमा को प्रभावित करने वाले निम्नलिखित गुण शामिल हैं।

  • Table
  • Column
  • Index
  • ForeignKey
  • NotMapped
  • InverseProperty

चाभी

एंटिटी फ्रेमवर्क प्रत्येक इकाई पर निर्भर करता है जिसका एक महत्वपूर्ण मूल्य है जो इसे ट्रैकिंग संस्थाओं के लिए उपयोग करता है। कोड फ़र्स्ट में से एक पर निर्भर करता है कि कोड फर्स्ट क्लास में से प्रत्येक में किस प्रॉपर्टी की कुंजी है।

  • कन्वेंशन "Id" नाम की एक प्रॉपर्टी की तलाश करने के लिए है या एक है जो क्लास के नाम और "Id" को जोड़ती है, जैसे कि "StudentId"।

  • संपत्ति डेटाबेस में एक प्राथमिक कुंजी स्तंभ के लिए मैप करेगी।

  • छात्र, पाठ्यक्रम और नामांकन कक्षाएं इस सम्मेलन का पालन करती हैं।

अब मान लेते हैं कि छात्र वर्ग ने आईडी के बजाय StdntID नाम का उपयोग किया है। जब कोड प्रथम को इस सम्मेलन से मेल खाने वाली संपत्ति नहीं मिलती है, तो यह एंटिटी फ्रेमवर्क की आवश्यकता के कारण एक अपवाद फेंक देगा कि आपके पास एक महत्वपूर्ण संपत्ति होनी चाहिए। आप मुख्य एनोटेशन का उपयोग यह निर्दिष्ट करने के लिए कर सकते हैं कि कौन सी संपत्ति को EntityKey के रूप में उपयोग किया जाना है।

आइए एक छात्र वर्ग के निम्नलिखित कोड पर एक नज़र डालें जिसमें StdntID शामिल है, लेकिन यह डिफ़ॉल्ट कोड प्रथम सम्मेलन का पालन नहीं करता है। तो इसे संभालने के लिए, एक मुख्य विशेषता जोड़ी जाती है जो इसे एक प्राथमिक कुंजी बना देगी।

public class Student {

   [Key]
   public int StdntID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

जब आप अपना एप्लिकेशन चलाते हैं और SQL सर्वर एक्सप्लोरर में अपने डेटाबेस में देखते हैं, तो आप देखेंगे कि प्राथमिक कुंजी अब स्टूडेंट्स टेबल में StdntID है।

एंटिटी फ्रेमवर्क कम्पोजिट कीज़ को भी सपोर्ट करता है। Composite keysप्राथमिक कुंजी भी है जिसमें एक से अधिक संपत्ति होती है। उदाहरण के लिए, आपके पास एक DrivingLicense क्लास है जिसकी प्राथमिक कुंजी लाइसेंसनंबर और इश्यूकाउंटरी का एक संयोजन है।

public class DrivingLicense {

   [Key, Column(Order = 1)]
   public int LicenseNumber { get; set; }
   [Key, Column(Order = 2)]
   public string IssuingCountry { get; set; }
   public DateTime Issued { get; set; }
   public DateTime Expires { get; set; }
}

जब आपके पास समग्र कुंजियाँ होती हैं, तो Entity Framework को आपको प्रमुख गुणों के एक क्रम को परिभाषित करने की आवश्यकता होती है। आप ऑर्डर को निर्दिष्ट करने के लिए कॉलम एनोटेशन का उपयोग कर सकते हैं।

समय-चिह्न

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

  • समवर्ती जाँच के लिए रोवर या टाइमस्टैम्प फ़ील्ड का उपयोग करना अधिक सामान्य है।

  • ConcurrencyCheck एनोटेशन का उपयोग करने के बजाय, आप अधिक विशिष्ट टाइमस्टैम्प एनोटेशन का उपयोग कर सकते हैं जब तक कि संपत्ति का प्रकार बाइट सरणी है।

  • आपके पास दिए गए वर्ग में केवल एक टाइमस्टैम्प संपत्ति हो सकती है।

आइए टाइमस्टैम्प संपत्ति को पाठ्यक्रम वर्ग में जोड़कर एक सरल उदाहरण देखें -

public class Course {

   public int CourseID { get; set; }
   public string Title { get; set; }
   public int Credits { get; set; }
   [Timestamp]
   public byte[] TStamp { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

जैसा कि आप ऊपर के उदाहरण में देख सकते हैं, टाइमस्टैम्प विशेषता को बाइट [] पाठ्यक्रम वर्ग की संपत्ति पर लागू किया जाता है। इसलिए, कोड प्रथम TStampपाठ्यक्रम तालिका में टाइमस्टैम्प कॉलम बनाएगा ।

ConcurrencyCheck

जब उपयोगकर्ता किसी इकाई को संपादित करता है या हटाता है, तो कंसीडरचेक एनोटेशन डेटाबेस में संगामिति जाँच के लिए एक या एक से अधिक संपत्तियों को चिह्नित करने की अनुमति देता है। यदि आप EF डिज़ाइनर के साथ काम कर रहे हैं, तो यह किसी प्रॉपर्टी के ConcurrencyMode को फिक्स्ड में सेट करने के साथ संरेखित करता है।

आइए एक सरल उदाहरण देखते हैं कि कोर्स क्लास में टाइटल प्रॉपर्टी को जोड़कर कॉनकरेन्सीकैच कैसे काम करता है।

public class Course {

   public int CourseID { get; set; }
   [ConcurrencyCheck]
   public string Title { get; set; }
   public int Credits { get; set; }
   [Timestamp, DataType("timestamp")]
   public byte[] TimeStamp { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

उपरोक्त पाठ्यक्रम वर्ग में, कॉन्सैरेक्टकैच विशेषता मौजूदा शीर्षक संपत्ति पर लागू होती है। अब, कोड फर्स्ट निम्न शीर्षक में दिखाए गए अनुसार आशावादी संगति के लिए जाँच करने के लिए अद्यतन कमांड में शीर्षक कॉलम शामिल करेगा।

exec sp_executesql N'UPDATE [dbo].[Courses]
   SET [Title] = @0
   WHERE (([CourseID] = @1) AND ([Title] = @2))
   ',N'@0 nvarchar(max) ,@1 int,@2 nvarchar(max) ',@0=N'Maths',@1=1,@2=N'Calculus'
go

आवश्यक एनोटेशन

आवश्यक एनोटेशन ईएफ को बताता है कि एक विशेष संपत्ति की आवश्यकता है। आइए निम्नलिखित छात्र वर्ग पर एक नज़र डालें जिसमें FirstMidName संपत्ति में आवश्यक आईडी जोड़ी जाती है। आवश्यक विशेषता ईएफ को यह सुनिश्चित करने के लिए मजबूर करेगी कि संपत्ति में डेटा है।

public class Student {

   [Key]
   public int StdntID { get; set; }

   [Required]
   public string LastName { get; set; }

   [Required]
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

जैसा कि उपरोक्त उदाहरण में देखा गया है, FirstMidName और LastName पर आवश्यक विशेषता लागू होती है। तो, कोड प्रथम निम्नलिखित छवि में दिखाए गए अनुसार छात्र तालिका में एक पूर्ण नॉट फर्स्टमीडनाम और लास्टनाम कॉलम नहीं बनाएगा।

अधिकतम लंबाई

MaxLength विशेषता आपको अतिरिक्त संपत्ति सत्यापन निर्दिष्ट करने की अनुमति देती है। इसे किसी डोमेन वर्ग की स्ट्रिंग या सरणी प्रकार की संपत्ति पर लागू किया जा सकता है। EF कोड सबसे पहले MaxLength विशेषता में निर्दिष्ट एक कॉलम का आकार निर्धारित करेगा।

चलिए निम्नलिखित पाठ्यक्रम वर्ग पर एक नज़र डालते हैं जिसमें MaxLength (24) विशेषता शीर्षक संपत्ति पर लागू होती है।

public class Course {

   public int CourseID { get; set; }
   [ConcurrencyCheck]
   [MaxLength(24)]
   public string Title { get; set; }
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

जब आप उपरोक्त एप्लिकेशन चलाते हैं, तो कोड फर्स्ट एक nvarchar (24) कॉलम टाइटल को कोर्सआईड टेबल में बनाएगा जैसा कि निम्नलिखित इमेज में दिखाया गया है।

जब उपयोगकर्ता शीर्षक सेट करता है जिसमें 24 से अधिक वर्ण होते हैं, तो EF EntityValidationError फेंक देगा।

MINLENGTH

MinLength विशेषता भी आपको अतिरिक्त संपत्ति सत्यापन निर्दिष्ट करने की अनुमति देती है, जैसे आपने MaxLength के साथ किया था। निम्न कोड में दिखाए गए अनुसार MinLength विशेषता का उपयोग MaxLength विशेषता के साथ भी किया जा सकता है।

public class Course {

   public int CourseID { get; set; }
   [ConcurrencyCheck]
   [MaxLength(24) , MinLength(5)]
   public string Title { get; set; }
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

EF EntityValidationError को फेंक देगा, यदि आप MinLength विशेषता में निर्दिष्ट लंबाई से कम या MaxLength विशेषता में निर्दिष्ट लंबाई से अधिक शीर्षक संपत्ति का मान सेट करते हैं।

स्ट्रिंग लंबाई

StringLength भी आपको MaxLength की तरह अतिरिक्त संपत्ति सत्यापन निर्दिष्ट करने की अनुमति देती है। एकमात्र अंतर यह है कि स्ट्रिंगलेंथ्रिटी विशेषता केवल डोमेन वर्गों की एक स्ट्रिंग प्रकार की संपत्ति पर लागू की जा सकती है।

public class Course {

   public int CourseID { get; set; }
   [StringLength (24)]
   public string Title { get; set; }
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

एंटिटी फ्रेमवर्क StringLength विशेषता के लिए एक संपत्ति के मूल्य को भी मान्य करता है। यदि उपयोगकर्ता शीर्षक सेट करता है जिसमें 24 से अधिक वर्ण हैं, तो EF EntityValidationError फेंक देगा।

टेबल

डिफ़ॉल्ट कोड पहला सम्मेलन वर्ग नाम के समान एक तालिका नाम बनाता है। यदि आप कोड को पहले डेटाबेस बनाने दे रहे हैं, और इसके द्वारा बनाई जा रही तालिकाओं का नाम भी बदलना चाहते हैं। फिर -

  • आप किसी मौजूदा डेटाबेस के साथ कोड फर्स्ट का उपयोग कर सकते हैं। लेकिन यह हमेशा ऐसा नहीं होता है कि कक्षाओं के नाम आपके डेटाबेस में तालिकाओं के नामों से मेल खाते हैं।

  • तालिका विशेषता इस डिफ़ॉल्ट सम्मेलन को ओवरराइड करती है।

  • EF कोड पहले एक निर्दिष्ट डोमेन वर्ग के लिए तालिका विशेषता में एक निर्दिष्ट नाम के साथ एक तालिका बनाएगा।

आइए निम्नलिखित उदाहरण पर एक नज़र डालते हैं जिसमें कक्षा का नाम छात्र है और सम्मेलन द्वारा, कोड फर्स्ट यह छात्रों के नाम वाली तालिका में मैप करेगा। यदि ऐसा नहीं है, तो आप तालिका का नाम तालिका विशेषता के साथ निर्दिष्ट कर सकते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

[Table("StudentsInfo")]
public class Student {

   [Key]
   public int StdntID { get; set; }
   [Required]
   public string LastName { get; set; }
   [Required]
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

अब आप देख सकते हैं कि तालिका विशेषता StudentsInfo के रूप में तालिका को निर्दिष्ट करती है। जब तालिका उत्पन्न हो जाती है, तो आपको तालिका नाम StudentsInfo दिखाई देगा जैसा कि निम्नलिखित छवि में दिखाया गया है।

आप केवल तालिका का नाम निर्दिष्ट नहीं कर सकते, लेकिन आप तालिका विशेषता का उपयोग करके तालिका के लिए एक स्कीमा भी निर्दिष्ट कर सकते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

[Table("StudentsInfo", Schema = "Admin")] 
public class Student {

   [Key]
   public int StdntID { get; set; }
   [Required]
   public string LastName { get; set; }
   [Required]
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

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

स्तंभ

यह तालिका विशेषता के समान भी है, लेकिन तालिका विशेषता स्तंभ व्यवहार को ओवरराइड करती है जबकि स्तंभ विशेषता स्तंभ व्यवहार को ओवरराइड करती है। डिफ़ॉल्ट कोड पहला सम्मेलन संपत्ति के नाम के समान एक कॉलम नाम बनाता है। यदि आप कोड को पहले डेटाबेस बनाने दे रहे हैं, और अपनी तालिकाओं में कॉलम का नाम भी बदलना चाहते हैं। फिर -

  • कॉलम विशेषता डिफ़ॉल्ट सम्मेलन को ओवरराइड करता है।

  • EF कोड पहले किसी दिए गए गुण के लिए कॉलम विशेषता में एक निर्दिष्ट नाम के साथ एक कॉलम बनाएगा।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें, जिसमें संपत्ति का नाम फर्स्टमिडनेम है और कन्वेंशन द्वारा, कोड फर्स्ट ने अनुमान लगाया कि यह फर्स्टमिडनेम नाम के कॉलम में जाएगा।

यदि ऐसा नहीं है, तो आप कॉलम का नाम कॉलम विशेषता के साथ निर्दिष्ट कर सकते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class Student {

   public int ID { get; set; }
   public string LastName { get; set; }
   [Column("FirstName")]
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

आप देख सकते हैं कि कॉलम विशेषता फर्स्टनाम के रूप में कॉलम को निर्दिष्ट करता है। जब तालिका उत्पन्न होती है, तो आपको कॉलम नाम FirstName दिखाई देगा जैसा कि निम्नलिखित छवि में दिखाया गया है।

सूची

इंडेक्स विशेषता को इकाई फ्रेमवर्क 6.1 में पेश किया गया था। यदि आप पहले वाले संस्करण का उपयोग कर रहे हैं, तो इस खंड की जानकारी लागू नहीं होती है।

  • IndexAttribute का उपयोग करके आप एक या अधिक कॉलम पर एक इंडेक्स बना सकते हैं।

  • एक या अधिक गुणों के लिए विशेषता जोड़ने से EF डेटाबेस में संबंधित अनुक्रमणिका बनाते समय डेटाबेस बनाएगा।

  • सूचकांक ज्यादातर मामलों में डेटा की पुनर्प्राप्ति को तेज और कुशल बनाते हैं। हालाँकि, अनुक्रमणिका के साथ किसी तालिका या दृश्य को ओवरलोड करने से अन्य ऑपरेशन जैसे आवेषण या अपडेट के प्रदर्शन को अप्रिय रूप से प्रभावित किया जा सकता है।

  • इंडेक्सिंग फ्रेमवर्क में इंडेक्सिंग नई सुविधा है जहां आप डेटाबेस से क्वेरी डेटा के लिए आवश्यक समय को कम करके अपने कोड फर्स्ट एप्लिकेशन के प्रदर्शन में सुधार कर सकते हैं।

  • आप अनुक्रमणिका विशेषता का उपयोग करके अपने डेटाबेस में अनुक्रमणिका जोड़ सकते हैं, और अनुक्रमणिका को आपके परिदृश्य के अनुकूल सर्वोत्तम रूप से प्राप्त करने के लिए डिफ़ॉल्ट अद्वितीय और संकुल सेटिंग्स को ओवरराइड कर सकते हैं।

  • डिफ़ॉल्ट रूप से, सूचकांक को IX_ <गुण नाम> नाम दिया जाएगा

आइए निम्नलिखित कोड पर एक नज़र डालें, जिसमें क्रेडिट्स के लिए पाठ्यक्रम वर्ग में सूचकांक विशेषता को जोड़ा गया है।

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   [Index]
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

आप देख सकते हैं कि अनुक्रमणिका गुण को क्रेडिट गुण पर लागू किया जाता है। जब तालिका जेनरेट होती है, तो आप सूचकांक में IX_Credits देखेंगे।

डिफ़ॉल्ट रूप से, अनुक्रमणिका गैर-अद्वितीय हैं, लेकिन आप सेटिंग का उपयोग कर सकते हैं IsUniqueयह निर्दिष्ट करने के लिए नामांकित पैरामीटर कि एक सूचकांक अद्वितीय होना चाहिए। निम्न कोड में दिखाए गए अनुसार निम्न उदाहरण एक अद्वितीय सूचकांक पेश करता है।

public class Course {
   public int CourseID { get; set; }
   [Index(IsUnique = true)]
	
   public string Title { get; set; }
   [Index]
	
   public int Credits { get; set; }
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

विदेशी कुंजी

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

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }
}

public class Student {
   [Key]
   public int StdntID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

डेटाबेस को जेनरेट करते समय कोड फर्स्ट एनरोलमेंट क्लास में स्टूडेंट की प्रॉपर्टी को देखता है और उसे पहचानता है, इस कन्वेंशन से कि वह क्लास के नाम "आईडी" से मेल खाता है, स्टूडेंट क्लास की विदेशी कुंजी के रूप में। हालाँकि, स्टूडेंट क्लास में कोई स्टूडेंट प्रॉपर्टी नहीं है, लेकिन स्टैडंट प्रॉपर्टी स्टूडेंट क्लास है।

इसका समाधान एनरोलमेंट में एक नेविगेशन प्रॉपर्टी बनाना है और कोड को पहले मदद करने के लिए फॉरेनकेय डेटानोटेशन का उपयोग करके यह समझा जा सकता है कि दो वर्गों के बीच संबंध कैसे बनाया जाए, जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
	
   public Grade? Grade { get; set; }
   public virtual Course Course { get; set; }
   [ForeignKey("StudentID")]
	
   public virtual Student Student { get; set; }
}

अब आप देख सकते हैं कि विदेशी संपत्ति विशेषता नेविगेशन संपत्ति पर लागू होती है।

NotMapped

कोड पहले के डिफ़ॉल्ट सम्मेलनों द्वारा, प्रत्येक संपत्ति जो एक समर्थित डेटा प्रकार की होती है और जिसमें डेटाबेस में गेटर्स और सेटर शामिल होते हैं। लेकिन आपके अनुप्रयोगों में हमेशा ऐसा नहीं होता है। NotMapped विशेषता इस डिफ़ॉल्ट सम्मेलन को ओवरराइड करती है। उदाहरण के लिए, आपके पास छात्र वर्ग में एक संपत्ति हो सकती है जैसे कि फादरनाम, लेकिन इसे संग्रहीत करने की आवश्यकता नहीं है। आप NotMapped विशेषता को एक FatherName गुण पर लागू कर सकते हैं, जिसे आप डेटाबेस में एक कॉलम नहीं बनाना चाहते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class Student {
   [Key]
   public int StdntID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
	
   public DateTime EnrollmentDate { get; set; }
   [NotMapped]

   public int FatherName { get; set; }
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

आप देख सकते हैं कि NotMapped विशेषता FatherName गुण पर लागू होती है। जब तालिका उत्पन्न होती है, तो आप देखेंगे कि फादरनाम कॉलम किसी डेटाबेस में नहीं बनाया जाएगा, लेकिन यह छात्र वर्ग में मौजूद है।

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

InverseProperty

InverseProperty का उपयोग तब किया जाता है जब आपके पास कक्षाओं के बीच कई संबंध होते हैं। नामांकन कक्षा में, आप वर्तमान पाठ्यक्रम और पिछले पाठ्यक्रम में दाखिला लेने वालों पर नज़र रखना चाहते हैं। चलो नामांकन वर्ग के लिए दो नेविगेशन गुण जोड़ते हैं।

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course CurrCourse { get; set; }
   public virtual Course PrevCourse { get; set; }
   public virtual Student Student { get; set; }
}

इसी तरह, आपको इन गुणों द्वारा संदर्भित पाठ्यक्रम वर्ग में भी जोड़ना होगा। पाठ्यक्रम वर्ग में नेविगेशन गुण वापस एनरॉलमेंट वर्ग में हैं, जिसमें सभी वर्तमान और पिछले नामांकन शामिल हैं।

public class Course {

   public int CourseID { get; set; }
   public string Title { get; set; }
   [Index]

   public int Credits { get; set; }
   public virtual ICollection<Enrollment> CurrEnrollments { get; set; }
   public virtual ICollection<Enrollment> PrevEnrollments { get; set; }
}

कोड प्रथम {वर्ग नाम} _ {प्राथमिक कुंजी} विदेशी कुंजी स्तंभ बनाता है, यदि विदेशी कुंजी संपत्ति किसी विशेष वर्ग में शामिल नहीं है जैसा कि उपरोक्त वर्गों में दिखाया गया है। जब डेटाबेस उत्पन्न होता है, तो आपको निम्नलिखित विदेशी कुंजियाँ दिखाई देंगी।

जैसा कि आप देख सकते हैं कि कोड पहले दो वर्गों में गुणों का मिलान करने में सक्षम नहीं है। नामांकन के लिए डेटाबेस तालिका में CurrCourse के लिए एक विदेशी कुंजी और PrevCourse के लिए एक होना चाहिए, लेकिन Code First में चार विदेशी कुंजी गुण बनाए जाएंगे, अर्थात

  • CurrCourse _CourseID
  • प्रीवार्क _CourseID
  • Course_CourseID, और
  • Course_CourseID1

इन समस्याओं को ठीक करने के लिए, आप संपत्तियों के संरेखण को निर्दिष्ट करने के लिए InverseProperty एनोटेशन का उपयोग कर सकते हैं।

public class Course {

   public int CourseID { get; set; }
   public string Title { get; set; }
   [Index]

   public int Credits { get; set; }
   [InverseProperty("CurrCourse")]

   public virtual ICollection<Enrollment> CurrEnrollments { get; set; }
   [InverseProperty("PrevCourse")]

   public virtual ICollection<Enrollment> PrevEnrollments { get; set; }
}

जैसा कि आप देख सकते हैं कि InverseProperty विशेषता उपरोक्त कोर्स वर्ग में लागू की जाती है, यह निर्दिष्ट करके कि यह किस नामांकन वर्ग की संदर्भ संपत्ति है। अब, कोड प्रथम एक डेटाबेस उत्पन्न करेगा और नामांकन तालिका में केवल दो विदेशी कुंजी कॉलम बनाएगा जैसा कि निम्नलिखित छवि में दिखाया गया है।

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

धाराप्रवाह एपीआई मॉडल कॉन्फ़िगरेशन को निर्दिष्ट करने का एक उन्नत तरीका है जो डेटा एनोटेशन के साथ संभव नहीं होने वाले कुछ और उन्नत कॉन्फ़िगरेशन के अलावा उन सभी डेटा को कवर कर सकता है। डेटा एनोटेशन और धाराप्रवाह एपीआई का एक साथ उपयोग किया जा सकता है, लेकिन कोड फर्स्ट, धाराप्रवाह एपीआई> डेटा एनोटेशन> डिफ़ॉल्ट सम्मेलनों को वरीयता देता है।

  • धाराप्रवाह एपीआई आपके डोमेन वर्गों को कॉन्फ़िगर करने का एक और तरीका है।

  • कोड पहले धाराप्रवाह एपीआई सबसे अधिक आपके व्युत्पन्न DbContext पर OnModelCreating विधि को ओवरराइड करके पहुंचता है।

  • धाराप्रवाह एपीआई DataAnnotations की तुलना में कॉन्फ़िगरेशन के लिए अधिक कार्यक्षमता प्रदान करता है। धाराप्रवाह एपीआई निम्न प्रकार के मैपिंग का समर्थन करता है।

इस अध्याय में, हम उस सरल उदाहरण को जारी रखेंगे जिसमें छात्र, पाठ्यक्रम और नामांकन कक्षाएं और MyContext नाम के साथ एक संदर्भ वर्ग शामिल है जैसा कि निम्नलिखित कोड में दिखाया गया है।

using System.Data.Entity; 
using System.Linq; 
using System.Text;
using System.Threading.Tasks;  

namespace EFCodeFirstDemo {

   class Program {
      static void Main(string[] args) {}
   }
   
   public enum Grade {
      A, B, C, D, F
   }

   public class Enrollment {
      public int EnrollmentID { get; set; }
      public int CourseID { get; set; }
      public int StudentID { get; set; }
      public Grade? Grade { get; set; }
		
      public virtual Course Course { get; set; }
      public virtual Student Student { get; set; }
   }

   public class Student {
      public int ID { get; set; }
      public string LastName { get; set; }
      public string FirstMidName { get; set; }
		
      public DateTime EnrollmentDate { get; set; }
		
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }

   public class Course {
      public int CourseID { get; set; }
      public string Title { get; set; }
      public int Credits { get; set; }
		
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }

   public class MyContext : DbContext {
      public virtual DbSet<Course> Courses { get; set; }
      public virtual DbSet<Enrollment> Enrollments { get; set; }
      public virtual DbSet<Student> Students { get; set; }
   }

}

धाराप्रवाह एपीआई तक पहुँचने के लिए आपको DbContext में OnModelCreating विधि को ओवरराइड करना होगा। आइए एक सरल उदाहरण देखें, जिसमें हम निम्नलिखित तालिका में दिखाए गए अनुसार FirstMidName से FirstName तक छात्र तालिका में कॉलम नाम का नाम बदल देंगे।

public class MyContext : DbContext {

   protected override void OnModelCreating(DbModelBuilder modelBuilder) {
      modelBuilder.Entity<Student>().Property(s ⇒ s.FirstMidName)
      .HasColumnName("FirstName");}

      public virtual DbSet<Course> Courses { get; set; }
      public virtual DbSet<Enrollment> Enrollments { get; set; }
      public virtual DbSet<Student> Students { get; set; }
}

DbModelBuilder का उपयोग CLR कक्षाओं को डेटाबेस स्कीमा में मैप करने के लिए किया जाता है। यह मुख्य वर्ग है और जिस पर आप अपने सभी डोमेन वर्गों को कॉन्फ़िगर कर सकते हैं। इकाई डेटा मॉडल (EDM) के निर्माण के लिए यह कोड केंद्रित दृष्टिकोण कोड प्रथम के रूप में जाना जाता है।

धाराप्रवाह एपीआई विभिन्न कोड प्रथम सम्मेलनों को पार करने के लिए संस्थाओं और इसके गुणों को कॉन्फ़िगर करने के लिए कई महत्वपूर्ण तरीके प्रदान करता है। नीचे उनमें से कुछ हैं।

अनु क्रमांक। विधि का नाम और विवरण
1

ComplexType<TComplexType>

एक प्रकार को मॉडल में एक जटिल प्रकार के रूप में पंजीकृत करता है और एक वस्तु लौटाता है जिसका उपयोग जटिल प्रकार को कॉन्फ़िगर करने के लिए किया जा सकता है। कॉन्फ़िगरेशन की कई पंक्तियों को निष्पादित करने के लिए एक ही प्रकार के लिए इस विधि को कई बार कहा जा सकता है।

2

Entity<TEntityType>

मॉडल के हिस्से के रूप में एक इकाई प्रकार को पंजीकृत करता है और एक वस्तु लौटाता है जिसका उपयोग इकाई को कॉन्फ़िगर करने के लिए किया जा सकता है। एक ही इकाई को कॉन्फ़िगरेशन की कई लाइनें करने के लिए इस विधि को कई बार कहा जा सकता है।

3

HasKey<TKey>

इस इकाई प्रकार के लिए प्राथमिक कुंजी गुण (विन्यासों) को कॉन्फ़िगर करता है।

4

HasMany<TTargetEntity>

इस इकाई प्रकार से कई संबंध कॉन्फ़िगर करता है।

5

HasOptional<TTargetEntity>

इस इकाई प्रकार से एक वैकल्पिक संबंध कॉन्फ़िगर करता है। इकाई प्रकार के उदाहरण इस संबंध को निर्दिष्ट किए बिना डेटाबेस में सहेजे जा सकेंगे। डेटाबेस में विदेशी कुंजी अशक्त होगी।

6

HasRequired<TTargetEntity>

इस इकाई प्रकार से एक आवश्यक संबंध कॉन्फ़िगर करता है। जब तक यह संबंध निर्दिष्ट नहीं किया जाता है, तब तक इकाई प्रकार के उदाहरण डेटाबेस में सहेजे नहीं जा सकेंगे। डेटाबेस में विदेशी कुंजी गैर-अशक्त होगी।

7

Ignore<TProperty>

मॉडल से एक संपत्ति को छोड़ देता है ताकि इसे डेटाबेस में मैप न किया जा सके। (स्ट्रक्चरट्राइप टाइपफिगरेशन से प्रभावित <TStructuralType>)

8

Property<T>

इस प्रकार पर परिभाषित एक संरचनात्मक संपत्ति को कॉन्फ़िगर करता है। (स्ट्रक्चरट्राइप टाइपफिगरेशन से प्रभावित <TStructuralType>)

9

ToTable(String)

उस तालिका नाम को कॉन्फ़िगर करता है जिसे यह इकाई प्रकार मैप किया जाता है।

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

  • इकाई मानचित्रण
  • गुण मानचित्रण

इकाई मानचित्रण

एंटिटी मैपिंग बस कुछ सरल मैपिंग है जो एंटिटी फ्रेमवर्क की समझ को प्रभावित करेगा कि कैसे डेटाबेस को मैप किया जाता है। इन सभी पर हमने डेटा एनोटेशन में चर्चा की और यहां हम देखेंगे कि धाराप्रवाह एपीआई का उपयोग करके समान चीजों को कैसे प्राप्त किया जाए।

  • इसलिए इन कॉन्फ़िगरेशन को जोड़ने के लिए डोमेन कक्षाओं में जाने के बजाय, हम इसे संदर्भ के अंदर कर सकते हैं।

  • पहली चीज ऑनमॉडेलक्रिटिंग विधि को ओवरराइड करना है, जो मॉडलब्यूलर को काम करने के लिए देता है।

डिफ़ॉल्ट स्कीमा

डेटाबेस तैयार होने पर डिफ़ॉल्ट स्कीमा dbo होता है। डेटाबेस स्कीमा को सभी तालिकाओं, संग्रहीत प्रक्रियाओं, आदि के लिए उपयोग करने के लिए निर्दिष्ट करने के लिए आप DDModelBuilder पर HasDefaultSchema विधि का उपयोग कर सकते हैं।

आइए निम्नलिखित उदाहरण देखें जिसमें व्यवस्थापक स्कीमा लागू किया गया है।

public class MyContext : DbContext {
   public MyContext() : base("name = MyContextDB") {}

   protected override void OnModelCreating(DbModelBuilder modelBuilder) {
      //Configure default schema
      modelBuilder.HasDefaultSchema("Admin");
   }
	
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

तालिका के लिए नक्शा इकाई

डिफॉल्ट कन्वेंशन के साथ, कोड फर्स्ट, डेटाबेस टेबल को संदर्भ वर्ग में डीबीएसएस गुण जैसे कि पाठ्यक्रम, नामांकन और छात्रों के साथ बनाएगा। लेकिन यदि आप अलग-अलग तालिका नाम चाहते हैं, तो आप इस सम्मेलन को ओवरराइड कर सकते हैं और DbSet गुणों की तुलना में एक अलग तालिका नाम प्रदान कर सकते हैं, जैसा कि निम्नलिखित कोड में दिखाया गया है।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   //Map entity to table
   modelBuilder.Entity<Student>().ToTable("StudentData");
   modelBuilder.Entity<Course>().ToTable("CourseDetail");
   modelBuilder.Entity<Enrollment>().ToTable("EnrollmentInfo");
}

जब डेटाबेस उत्पन्न होता है, तो आपको ऑनमोडेलक्रिटिंग विधि में निर्दिष्ट तालिका नाम दिखाई देगा।

इकाई विभाजन (कई तालिका के लिए नक्शा इकाई)

एंटिटी स्प्लिटिंग आपको एक ही कक्षा में कई तालिकाओं से आने वाले डेटा को संयोजित करने देता है और इसका उपयोग केवल उन तालिकाओं के साथ किया जा सकता है जिनके बीच एक-से-एक संबंध होता है। आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें छात्र जानकारी को दो तालिकाओं में मैप किया गया है।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {
   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   //Map entity to table
   modelBuilder.Entity<Student>().Map(sd ⇒ {
      sd.Properties(p ⇒ new { p.ID, p.FirstMidName, p.LastName });
      sd.ToTable("StudentData");
   })

   .Map(si ⇒ {
      si.Properties(p ⇒ new { p.ID, p.EnrollmentDate });
      si.ToTable("StudentEnrollmentInfo");
   });

   modelBuilder.Entity<Course>().ToTable("CourseDetail");
   modelBuilder.Entity<Enrollment>().ToTable("EnrollmentInfo");
}

उपरोक्त कोड में, आप देख सकते हैं कि स्टूडेंट एंटिटी निम्नलिखित दो तालिकाओं में विभाजित हो गई है, स्टूडेंटडेटा टेबल के लिए कुछ गुणों की मैपिंग और मैप विधि के उपयोग से स्टूडेंटइनरोलमेंटइन्फो टेबल में कुछ गुण।

  • StudentData - छात्र FirstMidName और अंतिम नाम शामिल हैं।

  • StudentEnrollmentInfo - नामांकन शामिल है।

जब डेटाबेस उत्पन्न होता है तो आप अपने डेटाबेस में निम्न तालिकाएँ देखते हैं जैसा कि निम्नलिखित छवि में दिखाया गया है।

गुण मानचित्रण

संपत्ति विधि का उपयोग किसी इकाई या जटिल प्रकार से संबंधित प्रत्येक संपत्ति के लिए विशेषताओं को कॉन्फ़िगर करने के लिए किया जाता है। किसी दिए गए गुण के लिए कॉन्फ़िगरेशन ऑब्जेक्ट प्राप्त करने के लिए संपत्ति विधि का उपयोग किया जाता है। आप धाराप्रवाह एपीआई का उपयोग करके अपने डोमेन वर्गों के गुणों को मैप और कॉन्फ़िगर भी कर सकते हैं।

एक प्राथमिक कुंजी को कॉन्फ़िगर करना

प्राथमिक कुंजी के लिए डिफ़ॉल्ट सम्मेलन हैं -

  • वर्ग एक संपत्ति को परिभाषित करता है जिसका नाम "आईडी" या "आईडी" है
  • "आईडी" या "आईडी" के बाद वर्ग का नाम

यदि आपकी कक्षा प्राथमिक कुंजी के लिए डिफ़ॉल्ट सम्मेलनों का पालन नहीं करती है जैसा कि छात्र वर्ग के निम्नलिखित कोड में दिखाया गया है -

public class Student {
   public int StdntID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

फिर एक संपत्ति को प्राथमिक कुंजी के रूप में स्पष्ट रूप से सेट करने के लिए, आप निम्न कोड में दिखाए गए तरीके से हस्की विधि का उपयोग कर सकते हैं -

protected override void OnModelCreating(DbModelBuilder modelBuilder) {
   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");
	
   // Configure Primary Key
   modelBuilder.Entity<Student>().HasKey<int>(s ⇒ s.StdntID); 
}

कॉलम कॉन्फ़िगर करें

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

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   //Configure EnrollmentDate Column
   modelBuilder.Entity<Student>().Property(p ⇒ p.EnrollmentDate)
	
   .HasColumnName("EnDate")
   .HasColumnType("DateTime")
   .HasColumnOrder(2);
}

MaxLength संपत्ति कॉन्फ़िगर करें

निम्नलिखित उदाहरण में, कोर्स शीर्षक संपत्ति 24 वर्णों से अधिक नहीं होनी चाहिए। जब उपयोगकर्ता 24 वर्णों से अधिक मूल्य निर्दिष्ट करता है, तो उपयोगकर्ता को DbEntityValidationException अपवाद मिलेगा।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {
   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");
   modelBuilder.Entity<Course>().Property(p ⇒ p.Title).HasMaxLength(24);
}

Null या NotNull प्रॉपर्टी को कॉन्फ़िगर करें

निम्नलिखित उदाहरण में, कोर्स टाइटल प्रॉपर्टी की आवश्यकता होती है, इसलिए NotRull कॉलम बनाने के लिए IsRequired विधि का उपयोग किया जाता है। इसी तरह, छात्र नामांकन नामांकन वैकल्पिक है, इसलिए हम निम्नलिखित कॉलम में दिखाए गए अनुसार इस कॉलम में एक शून्य मान की अनुमति देने के लिए IsOptional विधि का उपयोग करेंगे।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");
   modelBuilder.Entity<Course>().Property(p ⇒ p.Title).IsRequired();
   modelBuilder.Entity<Student>().Property(p ⇒ p.EnrollmentDate).IsOptional();
	
   //modelBuilder.Entity<Student>().Property(s ⇒ s.FirstMidName)
   //.HasColumnName("FirstName"); 
}

रिश्तों का विन्यास

एक संबंध, डेटाबेस के संदर्भ में, एक ऐसी स्थिति है जो दो संबंधपरक डेटाबेस तालिकाओं के बीच मौजूद है, जब एक तालिका में एक विदेशी कुंजी होती है जो अन्य तालिका की प्राथमिक कुंजी को संदर्भित करती है। कोड प्रथम के साथ काम करते समय, आप अपने डोमेन सीएलआर कक्षाओं को परिभाषित करके अपने मॉडल को परिभाषित करते हैं। डिफ़ॉल्ट रूप से, एंटिटी फ्रेमवर्क आपकी कक्षाओं को डेटाबेस स्कीमा में मैप करने के लिए कोड फर्स्ट कन्वेंशन का उपयोग करता है।

  • यदि आप कोड फर्स्ट नामकरण सम्मेलनों का उपयोग करते हैं, तो ज्यादातर मामलों में आप विदेशी कुंजी और नेविगेशन गुणों के आधार पर अपनी तालिकाओं के बीच संबंध स्थापित करने के लिए कोड फर्स्ट पर भरोसा कर सकते हैं।

  • यदि वे उन सम्मेलनों के साथ नहीं मिलते हैं, तो ऐसे कॉन्फ़िगरेशन भी हैं जिनका उपयोग आप कक्षाओं के बीच संबंधों को प्रभावित करने के लिए कर सकते हैं और उन संबंधों को डेटाबेस में कैसे महसूस किया जाता है जब आप कोड फ़र्स्ट में कॉन्फ़िगरेशन जोड़ रहे हैं।

  • उनमें से कुछ डेटा एनोटेशन में उपलब्ध हैं और आप एक धाराप्रवाह एपीआई के साथ कुछ और भी अधिक जटिल आवेदन कर सकते हैं।

एक-से-एक संबंध कॉन्फ़िगर करें

जब आप अपने मॉडल में एक-से-एक संबंध परिभाषित करते हैं, तो आप प्रत्येक कक्षा में एक संदर्भ नेविगेशन संपत्ति का उपयोग करते हैं। डेटाबेस में, दोनों तालिकाओं में संबंध के दोनों ओर केवल एक ही रिकॉर्ड हो सकता है। प्रत्येक प्राथमिक कुंजी मान संबंधित तालिका में केवल एक रिकॉर्ड (या कोई रिकॉर्ड) से संबंधित नहीं है।

  • एक-से-एक संबंध बनाया जाता है यदि दोनों संबंधित स्तंभ प्राथमिक कुंजी हैं या अद्वितीय अवरोध हैं।

  • एक-से-एक रिश्ते में, प्राथमिक कुंजी अतिरिक्त रूप से एक विदेशी कुंजी के रूप में कार्य करती है और दोनों तालिका के लिए कोई अलग विदेशी कुंजी स्तंभ नहीं है।

  • इस प्रकार का संबंध सामान्य नहीं है क्योंकि इस तरह से संबंधित अधिकांश जानकारी सभी एक ही तालिका में होगी।

आइए निम्नलिखित उदाहरण पर एक नज़र डालें जहां हम एक-से-एक संबंध बनाने के लिए अपने मॉडल में एक और वर्ग जोड़ेंगे।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual StudentLogIn StudentLogIn { get; set; }
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

public class StudentLogIn {
   [Key, ForeignKey("Student")]
   public int ID { get; set; }
   public string EmailID { get; set; }
   public string Password { get; set; }
	
   public virtual Student Student { get; set; }
}

जैसा कि आप ऊपर दिए गए कोड में देख सकते हैं कि Key और ForeignKey विशेषताएँ का उपयोग StudentLogIn वर्ग में ID संपत्ति के लिए किया जाता है, ताकि इसे प्राथमिक कुंजी और साथ ही विदेशी कुंजी के रूप में चिह्नित किया जा सके।

धाराप्रवाह एपीआई का उपयोग करके छात्र और छात्र के बीच एक-से-शून्य या एक संबंध को कॉन्फ़िगर करने के लिए, आपको निम्नलिखित कोड में दिखाए गए अनुसार ऑनमॉडेलक्रिटिंग विधि को ओवरराइड करने की आवश्यकता है।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   // Configure ID as PK for StudentLogIn
   modelBuilder.Entity<StudentLogIn>()
   .HasKey(s ⇒ s.ID);

   // Configure ID as FK for StudentLogIn
   modelBuilder.Entity<Student>()
   
   .HasOptional(s ⇒ s.StudentLogIn) //StudentLogIn is optional
   .WithRequired(t ⇒ t.Student); // Create inverse relationship
}

ज्यादातर मामलों में, एंटिटी फ्रेमवर्क यह अनुमान लगा सकता है कि किस प्रकार पर निर्भर है और जो रिश्ते में प्रमुख है। हालाँकि, जब रिश्ते के दोनों सिरों की आवश्यकता होती है या दोनों पक्ष वैकल्पिक होते हैं तो एंटिटी फ्रेमवर्क आश्रित और प्रिंसिपल की पहचान नहीं कर सकता है। जब संबंध के दोनों सिरों की आवश्यकता होती है, तो आप निम्न कोड में दिखाए गए अनुसार HasRequired का उपयोग कर सकते हैं।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   // Configure ID as PK for StudentLogIn
   modelBuilder.Entity<StudentLogIn>()
   .HasKey(s ⇒ s.ID);

   // Configure ID as FK for StudentLogIn
   modelBuilder.Entity<Student>()
   .HasRequired(r ⇒ r.Student)
   .WithOptional(s ⇒ s.StudentLogIn);  
}

जब डेटाबेस उत्पन्न होता है, तो आप देखेंगे कि संबंध निम्न छवि में दिखाया गया है।

एक-से-कई संबंध कॉन्फ़िगर करें

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

  • इस प्रकार के संबंध में, तालिका A की एक पंक्ति में तालिका B में कई मिलान पंक्तियाँ हो सकती हैं, लेकिन तालिका B में एक पंक्ति में तालिका A में केवल एक मिलान पंक्ति हो सकती है।

  • विदेशी कुंजी को मेज पर परिभाषित किया गया है जो रिश्ते के कई अंत का प्रतिनिधित्व करता है।

  • उदाहरण के लिए, ऊपर दिए गए आरेख में छात्र और नामांकन तालिका में एक-टोमनी संबंध है, प्रत्येक छात्र के कई नामांकन हो सकते हैं, लेकिन प्रत्येक नामांकन केवल एक छात्र का है।

नीचे छात्र और नामांकन हैं जिनके बीच एक-से-कई संबंध हैं, लेकिन नामांकन तालिका में विदेशी कुंजी डिफ़ॉल्ट कोड प्रथम सम्मेलनों का पालन नहीं कर रही है।

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
	
   //StdntID is not following code first conventions name
   public int StdntID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }
}

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual StudentLogIn StudentLogIn { get; set; }
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

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

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   //Configure FK for one-to-many relationship
   modelBuilder.Entity<Enrollment>()

   .HasRequired<Student>(s ⇒ s.Student)
   .WithMany(t ⇒ t.Enrollments)
   .HasForeignKey(u ⇒ u.StdntID);  
}

जब डेटाबेस उत्पन्न होता है, तो आप देखेंगे कि संबंध निम्न छवि में दिखाया गया है।

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

कई-कई-कई संबंधों को कॉन्फ़िगर करें

दोनों तालिकाओं में प्रत्येक रिकॉर्ड किसी भी संख्या में रिकॉर्ड (या कोई रिकॉर्ड) से संबंधित नहीं हो सकता है।

  • जंक्शन टेबल नामक तीसरी टेबल को परिभाषित करके आप ऐसा रिश्ता बना सकते हैं, जिसकी प्राथमिक कुंजी में टेबल ए और टेबल बी दोनों से विदेशी चाबियां होती हैं।

  • उदाहरण के लिए, छात्र तालिका और पाठ्यक्रम तालिका में कई-से-कई संबंध हैं।

निम्नलिखित छात्र और पाठ्यक्रम कक्षाएं हैं जिनमें छात्र और पाठ्यक्रम के कई-टॉमनी संबंध हैं, क्योंकि दोनों वर्गों में नेविगेशन गुण हैं छात्र और पाठ्यक्रम जो संग्रह हैं। दूसरे शब्दों में, एक इकाई का एक और इकाई संग्रह है।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Course> Courses { get; set; }
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   public int Credits { get; set; }
	
   public virtual ICollection<Student> Students { get; set; }
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

छात्र और पाठ्यक्रम के बीच कई-से-कई संबंधों को कॉन्फ़िगर करने के लिए, आप धाराप्रवाह एपीआई का उपयोग कर सकते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   // Configure many-to-many relationship
   modelBuilder.Entity<Student>()
   .HasMany(s ⇒ s.Courses) 
   .WithMany(s ⇒ s.Students);
}

जब डेटाबेस उत्पन्न होता है तो एक डिफ़ॉल्ट तालिका बनाने के लिए डिफ़ॉल्ट कोड प्रथम सम्मेलनों का उपयोग किया जाता है। परिणामस्वरूप, निम्न छवि में दिखाए गए अनुसार StudentCourses तालिका को Course_CourseID और Student_ID कॉलम के साथ बनाया गया है।

यदि आप तालिका का नाम और तालिका में स्तंभों के नाम निर्दिष्ट करना चाहते हैं, तो आपको मानचित्र विधि का उपयोग करके अतिरिक्त कॉन्फ़िगरेशन करने की आवश्यकता है।

protected override void OnModelCreating(DbModelBuilder modelBuilder) {

   //Configure default schema
   modelBuilder.HasDefaultSchema("Admin");

   // Configure many-to-many relationship 
   modelBuilder.Entity<Student>()

   .HasMany(s ⇒ s.Courses)
   .WithMany(s ⇒ s.Students)
   
   .Map(m ⇒ {
      m.ToTable("StudentCoursesTable");
      m.MapLeftKey("StudentID");
      m.MapRightKey("CourseID");
   }); 
}

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

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

एंटिटी फ्रेमवर्क में, बीज को EF 4.1 में पेश किया गया था और डेटाबेस इनिशियलाइज़र के साथ काम करता है। सामान्य विचार aSeed Methodएक डेटाबेस में डेटा को इनिशियलाइज़ करना है जो Code First द्वारा बनाया जा रहा है या माइग्रेशन द्वारा विकसित किया गया है। यह डेटा अक्सर परीक्षण डेटा है, लेकिन संदर्भ डेटा भी हो सकता है जैसे कि ज्ञात छात्रों की सूची, पाठ्यक्रम, आदि। जब डेटा को आरम्भ किया जाता है, तो यह निम्न कार्य करता है -

  • जाँचता है कि लक्ष्य डेटाबेस पहले से मौजूद है या नहीं।
  • यदि ऐसा होता है, तो वर्तमान कोड प्रथम मॉडल की तुलना डेटाबेस में मेटाडेटा में संग्रहीत मॉडल से की जाती है।
  • यदि वर्तमान मॉडल डेटाबेस में मॉडल से मेल नहीं खाता है तो डेटाबेस को हटा दिया जाता है।
  • डेटाबेस बनाया जाता है अगर यह गिरा दिया गया था या पहले स्थान पर मौजूद नहीं था।
  • यदि डेटाबेस बनाया गया था, तो आरंभीकृत बीज विधि कहा जाता है।

बीज विधि डेटाबेस संदर्भ ऑब्जेक्ट को इनपुट पैरामीटर के रूप में लेती है, और विधि में कोड उस ऑब्जेक्ट का उपयोग डेटाबेस में नई संस्थाओं को जोड़ने के लिए करता है। अपने डेटाबेस में डेटा को सीड करने के लिए, आपको सीड विधि को ओवरराइड करने की आवश्यकता है। आइए निम्नलिखित उदाहरण पर एक नज़र डालें जिसमें कुछ डिफ़ॉल्ट डेटा को आंतरिक कक्षा में डेटाबेस में शुरू किया जाता है।

private class UniDBInitializer<T> : DropCreateDatabaseAlways<MyContext> {

   protected override void Seed(MyContext context) {

      IList<Student> students = new List<Student>();

      students.Add(new Student() {
         FirstMidName = "Andrew", 
         LastName = "Peters", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      });

      students.Add(new Student() {
         FirstMidName = "Brice", 
         LastName = "Lambson", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      });

      students.Add(new Student() {
         FirstMidName = "Rowan", 
         LastName = "Miller", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      });

      foreach (Student student in students)
      context.Students.Add(student);
      base.Seed(context);
   }
}

उपरोक्त कोड में, छात्र तालिका आरंभीकृत की गई है। आपको इस DB initializer वर्ग को संदर्भ वर्ग में सेट करने की आवश्यकता है जैसा कि निम्नलिखित कोड में दिखाया गया है।

public MyContext() : base("name=MyContextDB") {
   Database.SetInitializer<MyContext>(new UniDBInitializer<MyContext>());
}

निम्नलिखित MyContext वर्ग का पूर्ण वर्ग कार्यान्वयन है, जिसमें DB initializer वर्ग भी शामिल है।

public class MyContext : DbContext {

   public MyContext() : base("name=MyContextDB") {
      Database.SetInitializer<MyContext>(new UniDBInitializer<MyContext>());
   }

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
	
   private class UniDBInitializer<T> : DropCreateDatabaseAlways<MyContext> {

      protected override void Seed(MyContext context) {

         IList<Student> students = new List<Student>();
			
         students.Add(new Student() {
            FirstMidName = "Andrew", 
            LastName = "Peters", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString()) 
         });

         students.Add(new Student() {
            FirstMidName = "Brice", 
            LastName = "Lambson", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         students.Add(new Student() {
            FirstMidName = "Rowan", 
            LastName = "Miller", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         foreach (Student student in students)
         context.Students.Add(student);
         base.Seed(context);
      }
   } 
}

जब उपरोक्त उदाहरण संकलित और निष्पादित किया जाता है, तो आप डेटा को डेटाबेस में निम्न छवि में दिखाए अनुसार देख सकते हैं।

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

एंटिटी फ्रेमवर्क 4.3 में एक नया कोड फर्स्ट माइग्रेशन फीचर शामिल है जो आपको डेटाबेस स्कीमा को समय-समय पर अपने मॉडल में बदलाव के रूप में विकसित करने की अनुमति देता है। अधिकांश डेवलपर्स के लिए, यह 4.1 और 4.2 रिलीज़ से डेटाबेस इनिशियलाइज़र विकल्पों पर एक बड़ा सुधार है, जो आपको डेटाबेस को मैन्युअल रूप से अपडेट या ड्रॉप करने और इसे फिर से बनाने की आवश्यकता होती है जब आपका मॉडल बदल जाता है।

  • एंटिटी फ्रेमवर्क 4.3 से पहले, यदि आपके पास पहले से डेटा (बीज डेटा के अलावा) या आपके डेटाबेस में मौजूदा संग्रहीत कार्यविधियाँ, ट्रिगर आदि हैं, तो ये रणनीतियाँ पूरे डेटाबेस को छोड़ने और इसे फिर से बनाने के लिए उपयोग की जाती हैं, इसलिए आप डेटा और अन्य DB खो देंगे वस्तुओं।

  • माइग्रेशन के साथ, यह स्वचालित रूप से डेटाबेस स्कीमा को अपडेट करेगा, जब आपका मॉडल किसी भी मौजूदा डेटा या अन्य डेटाबेस ऑब्जेक्ट को खोए बिना बदल जाता है।

  • यह एक नया डेटाबेस इनिशियलाइज़र का उपयोग करता है जिसे MigrateDatabaseToLatestVersion कहा जाता है।

प्रवासन दो प्रकार के होते हैं -

  • स्वचालित प्रवासन
  • कोड आधारित प्रवासन

स्वचालित प्रवासन

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

आइए स्वचालित माइग्रेशन की निम्न चरण-दर-चरण प्रक्रिया पर एक नज़र डालें।

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

इस उदाहरण में हम अपने 3 बुनियादी वर्गों जैसे कि छात्र, पाठ्यक्रम और नामांकन के साथ शुरू करेंगे, जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }

}

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   [Index]
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

निम्नलिखित संदर्भ वर्ग है।

public class MyContext : DbContext {
   public MyContext() : base("MyContextDB") {}
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

एप्लिकेशन को चलाने से पहले, आपको स्वचालित माइग्रेशन को सक्षम करना होगा।

Step 1 - टूल्स से पैकेज पैकेज मैंगर कंसोल खोलें → नुगेट पैकेज मैंगर → पैकेज मैंगर कंसोल।

Step 2 - स्वचालित माइग्रेशन को सक्षम करने के लिए पैकेज मैनेजर कंसोल में निम्न कमांड चलाएं।

PM> enable-migrations -EnableAutomaticMigrations:$true

Step 3 - एक बार कमांड सफलतापूर्वक चलने के बाद, यह आपकी परियोजना के माइग्रेशन फ़ोल्डर में एक आंतरिक मोहरबंद विन्यास वर्ग बनाता है जैसा कि निम्नलिखित कोड में दिखाया गया है।

namespace EFCodeFirstDemo.Migrations {

   using System;
   using System.Data.Entity;
   using System.Data.Entity.Migrations;
   using System.Linq;
	
   internal sealed class Configuration : DbMigrationsConfiguration<EFCodeFirstDemo.MyContext> {

      public Configuration() {
         AutomaticMigrationsEnabled = true;
         ContextKey = "EFCodeFirstDemo.MyContext";
      }

      protected override void Seed(EFCodeFirstDemo.MyContext context) {

         //  This method will be called after migrating to the latest version.
         //  You can use the DbSet<T>.AddOrUpdate() helper extension method
         //  to avoid creating duplicate seed data. E.g.

         //  context.People.AddOrUpdate(
            //  p ⇒ p.FullName, 
            //  new Person { FullName = "Andrew Peters" }, 
            //  new Person { FullName = "Brice Lambson" }, 
            //  new Person { FullName = "Rowan Miller" }
         //  );
      }
   }
}

Step 4 - नई डीबी आरंभीकरण रणनीति के साथ संदर्भ वर्ग में डेटाबेस इनिशियलाइज़र सेट करें MigrateDatabaseToLatestVersion।

public class MyContext : DbContext {

   public MyContext() : base("MyContextDB") {
      Database.SetInitializer(new MigrateDatabaseToLatestVersion<MyContext, 
         EFCodeFirstDemo.Migrations.Configuration>("MyContextDB"));
   }

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }

}

Step 5- आपने स्वचालित माइग्रेशन सेट किया है। जब आप अपने एप्लिकेशन को निष्पादित करते हैं, तो यह स्वचालित रूप से माइग्रेशन का ध्यान रखेगा, जब आप मॉडल बदलते हैं।

Step 6- जैसा कि आप देख सकते हैं कि आपके डेटाबेस में अन्य टेबल के साथ एक सिस्टम टेबल __ माइग्रेशनहिस्टर भी बनाया गया है। __MigrationHistory में, स्वचालित माइग्रेशन डेटाबेस परिवर्तनों के इतिहास को बनाए रखता है।

Step 7- जब आप अपने डोमेन वर्ग के रूप में एक और इकाई वर्ग जोड़ते हैं और अपने आवेदन को निष्पादित करते हैं, तो यह आपके डेटाबेस में तालिका बनाएगा। चलिए निम्नलिखित StudentLogIn क्लास जोड़ें।

public class StudentLogIn {
   [Key, ForeignKey("Student")]
   public int ID { get; set; }
   public string EmailID { get; set; }
   public string Password { get; set; }
	
   public virtual Student Student { get; set; }
}

Step 8 - उपरोक्त कोड के लिए DBSet को अपने संदर्भ वर्ग में जोड़ना न भूलें, जैसा कि निम्नलिखित कोड में दिखाया गया है।

public virtual DbSet<StudentLogIn> StudentsLogIn { get; set; }

Step 9 - अपना एप्लिकेशन फिर से चलाएँ और आप देखेंगे कि StudentsLogIn टेबल आपके डेटाबेस में जुड़ गया है।

स्वचालित माइग्रेशन के लिए उल्लिखित उपरोक्त चरण केवल आपकी इकाई के लिए काम करेंगे। उदाहरण के लिए, किसी अन्य इकाई वर्ग को जोड़ने या मौजूदा निकाय वर्ग को निकालने के लिए यह सफलतापूर्वक माइग्रेट करेगा। लेकिन अगर आप अपनी इकाई वर्ग में कोई संपत्ति जोड़ते या निकालते हैं तो यह एक अपवाद होगा।

Step 10 - संपत्ति माइग्रेशन को संभालने के लिए आपको कॉन्फ़िगरेशन वर्ग कंस्ट्रक्टर में AutomaticMigrationDataLossAllowed = true सेट करना होगा।

public Configuration() {
   AutomaticMigrationsEnabled = true;
   AutomaticMigrationDataLossAllowed = true;
   ContextKey = "EFCodeFirstDemo.MyContext";
}

कोड आधारित प्रवासन

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

  • जब आप एंटिटी क्लासेस को जोड़ते, हटाते या बदलते हैं या अपना DbContext क्लास बदलते हैं, तो अगली बार जब आप एप्लिकेशन को चलाते हैं तो यह स्वचालित रूप से आपके मौजूदा डेटाबेस को हटा देता है, एक नया बनाता है जो मॉडल से मेल खाता है, और इसे टेस्ट डेटा के साथ बीज देता है।

  • कोड फ़र्स्ट माइग्रेशन फ़ीचर इस समस्या को हल करता है, कोड फ़ॉरमैट को अपडेट करने और डेटाबेस को फिर से बनाने के बजाय डेटाबेस स्कीमा को अपडेट करने में सक्षम बनाता है। एप्लिकेशन को परिनियोजित करने के लिए, आपको माइग्रेशन सक्षम करना होगा।

यहाँ डेटाबेस में परिवर्तन को स्थानांतरित करने का मूल नियम है -

  • माइग्रेशन सक्षम करें
  • माइग्रेशन जोड़ें
  • डेटाबेस अद्यतन करें

आइए कोड-बेस प्रवासन की निम्नलिखित चरण-दर-चरण प्रक्रिया पर एक नज़र डालें।

जब आप कोड पहले दृष्टिकोण का उपयोग करते हैं, तो आपके पास आवेदन के लिए डेटाबेस नहीं होता है।

इस उदाहरण में हम अपने 3 बुनियादी वर्गों जैसे कि छात्र, पाठ्यक्रम और नामांकन के साथ फिर से शुरू करेंगे जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }

}

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   [Index]
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

निम्नलिखित संदर्भ वर्ग है।

public class MyContext : DbContext {

   public MyContext() : base("MyContextDB") {
      Database.SetInitializer(new MigrateDatabaseToLatestVersion<
         MyContext, EFCodeFirstDemo.Migrations.Configuration>("MyContextDB"));
   }

   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }

}

Step 1 - एप्लिकेशन को चलाने से पहले आपको माइग्रेशन सक्षम करना होगा।

Step 2 - टूल्स से पैकेज मैनेजर कंसोल खोलें → नुगेट पैकेज मंगर → पैकेज मंगर कंसोल।

Step 3 - माइग्रेशन पहले से ही सक्षम है, अब अपने एप्लिकेशन में निम्न कमांड को निष्पादित करके माइग्रेशन जोड़ें।

PM> add-migration "UniDB Schema"

Step 4 - जब कमांड को सफलतापूर्वक निष्पादित किया जाता है, तो आप देखेंगे कि माइग्रेशन फ़ोल्डर में एक नई फाइल बनाई गई है, जो आपके द्वारा कमांड में दिए गए पैरामीटर के नाम के साथ टाइमस्टैम्प उपसर्ग है जैसा कि निम्नलिखित छवि में दिखाया गया है।

Step 5 - आप "अपडेट-डेटाबेस" कमांड का उपयोग करके डेटाबेस बना या अपडेट कर सकते हैं।

PM> Update-Database -Verbose

"-Verbose" ध्वज कंसोल में लक्ष्य डेटाबेस पर लागू किए जा रहे SQL कथन को दिखाने के लिए निर्दिष्ट करता है।

Step 6 - चलो छात्र वर्ग में एक और संपत्ति 'आयु' जोड़ते हैं और फिर अपडेट स्टेटमेंट निष्पादित करते हैं।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public int Age { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

}

जब आप PM → Update-Database -Verbose को निष्पादित करते हैं, जब कमांड को सफलतापूर्वक निष्पादित किया जाता है, तो आप देखेंगे कि आपके डेटाबेस में नया कॉलम एज जोड़ा गया है।

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

इस अध्याय में, हम सीखेंगे कि डेटाबेस में परिवर्तन कैसे करें जब अनुप्रयोग में कई DbContext कक्षाएं हैं।

  • मल्टीपल DbContext को पहली बार Entity Framework 6.0 में पेश किया गया था।
  • एकाधिक संदर्भ कक्षाएं एक एकल डेटाबेस या दो अलग-अलग डेटाबेस से संबंधित हो सकती हैं।

हमारे उदाहरण में, हम एक ही डेटाबेस के लिए दो संदर्भ वर्गों को परिभाषित करेंगे। निम्नलिखित कोड में, छात्र और शिक्षक के लिए दो DbContext कक्षाएं हैं।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
}

public class MyStudentContext : DbContext {
   public MyStudentContext() : base("UniContextDB") {}
   public virtual DbSet<Student> Students { get; set; }
}

public class Teacher {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime HireDate { get; set; }
}

public class MyTeacherContext : DbContext {
   public MyTeacherContext() : base("UniContextDB") {}
   public virtual DbSet<Teacher> Teachers { get; set; }
}

जैसा कि आप उपरोक्त कोड में देख सकते हैं, "मॉडल" और "शिक्षक" नामक दो मॉडल हैं। प्रत्येक एक विशेष संबंधित संदर्भ वर्ग के साथ जुड़ा हुआ है, अर्थात, छात्र MyStudentContext के साथ जुड़ा हुआ है और शिक्षक MyTeacherContext के साथ जुड़ा हुआ है।

यहां डेटाबेस में परिवर्तन को स्थानांतरित करने का मूल नियम है, जब एक ही परियोजना के भीतर कई संदर्भ कक्षाएं हैं।

  • सक्षम-माइग्रेशन -ContextTypeName <DbContext-Name-with-Namespaces> MigrationsDirectory: <माइग्रेशन-निर्देशिका-नाम>

  • ऐड-माइग्रेशन -configuration <DbContext-Migrations-configuration-Class-withNamespaces> <माइग्रेशन-नाम>

  • अपडेट-डेटाबेस -configuration <DbContext-Migrations-कॉन्फ़िगरेशन-क्लास-with -Namespaces> -Verbose

पैकेज मैनेजर कंसोल में निम्नलिखित कमांड निष्पादित करके MyStudentContext के लिए माइग्रेशन सक्षम करें।

PM→ enable-migrations -ContextTypeName:EFCodeFirstDemo.MyStudentContext

एक बार इसे निष्पादित करने के बाद, हम मॉडल को माइग्रेशन इतिहास में जोड़ देंगे और उसके लिए, हमें उसी कंसोल में ऐड-माइग्रेशन कमांड को फायर करना होगा।

PM→ add-migration -configuration EFCodeFirstDemo.Migrations.Configuration Initial

आइए अब डेटाबेस में छात्रों और शिक्षकों की तालिकाओं में कुछ डेटा जोड़ते हैं।

static void Main(string[] args) {

   using (var context = new MyStudentContext()) {
	
      //// Create and save a new Students
      Console.WriteLine("Adding new students");

      var student = new Student {
         FirstMidName = "Alain", 
         LastName = "Bomer", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 24
      };

      context.Students.Add(student);

      var student1 = new Student {
         FirstMidName = "Mark",
         LastName = "Upston", 
         EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 30
      };

      context.Students.Add(student1);
      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.WriteLine("Press any key to exit...");
      Console.ReadKey();
   }

   using (var context = new MyTeacherContext()) {

      //// Create and save a new Teachers
      Console.WriteLine("Adding new teachers");

      var student = new Teacher {
         FirstMidName = "Alain", 
         LastName = "Bomer", 
         HireDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 24
      };

      context.Teachers.Add(student);

      var student1 = new Teacher {
         FirstMidName = "Mark", 
         LastName = "Upston", 
         HireDate = DateTime.Parse(DateTime.Today.ToString())
         //Age = 30
      };

      context.Teachers.Add(student1);
      context.SaveChanges();
  
      // Display all Teachers from the database
      var teachers = (from t in context.Teachers orderby t.FirstMidName
         select t).ToList<Teacher>();
		
      Console.WriteLine("Retrieve all teachers from the database:");

      foreach (var teacher in teachers) {
         string name = teacher.FirstMidName + " " + teacher.LastName;
         Console.WriteLine("ID: {0}, Name: {1}", teacher.ID, name);
      }

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

जब उपरोक्त कोड निष्पादित किया जाता है, तो आप देखेंगे कि निम्न छवि में दिखाए गए अनुसार दो अलग-अलग मॉडल के लिए दो अलग-अलग टेबल बनाए गए हैं।

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

एंटिटी फ्रेमवर्क 6 से पहले, एंटिटी फ्रेमवर्क उन संस्थाओं या जटिल प्रकारों को नहीं पहचानता था जो अन्य संस्थाओं या जटिल प्रकारों में निहित थे। जब एंटिटी फ्रेमवर्क ने मॉडल उत्पन्न किया, तो नेस्टेड प्रकार गायब हो गए।

आइए एक सरल उदाहरण देखें, जिसमें हमारे पास तीन संस्थाओं छात्र, पाठ्यक्रम और नामांकन के साथ हमारा मूल मॉडल है।

  • आइए एक संपत्ति पहचान जोड़ते हैं, जो एक व्यक्ति प्रकार है। व्यक्ति एक और इकाई है, जिसमें बर्थडे और फादरनाम गुण होते हैं।

  • एंटिटी फ्रेमवर्क शब्दों में, क्योंकि इसकी कोई पहचान नहीं है और यह एक इकाई का हिस्सा है, यह एक एंटिटी फ्रेमवर्क जटिल प्रकार है, और हमने वास्तव में एंटिटी फ्रेमवर्क के पहले संस्करण के बाद से जटिल प्रकारों के लिए समर्थन किया है।

  • निम्न कोड में दिखाया गया है कि व्यक्ति प्रकार नेस्टेड नहीं है।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
   public Person Identity { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

public class Person {

   public Person(string fatherName, DateTime birthDate) {
      FatherName = fatherName;
      BirthDate = birthDate;
   }
	
   public string FatherName { get; set; }
   public DateTime BirthDate { get; set; }
}

एंटिटी फ्रेमवर्क यह जान लेगा कि पर्सन प्रकारों को कैसे बनाए रखा जाए जब इसका उपयोग पिछले संस्करणों में भी किया जाए।

एंटिटी फ्रेमवर्क पावर टूल का उपयोग करके हम देखेंगे कि एंटिटी फ्रेमवर्क मॉडल की व्याख्या कैसे करता है। Program.cs फ़ाइल पर राइट क्लिक करें और Entity Framework चुनें → Entity Data Model (केवल पढ़ें)

अब आप देखेंगे कि छात्र वर्ग में आइडेंटिटी प्रॉपर्टी को परिभाषित किया गया है।

यदि यह व्यक्ति वर्ग किसी अन्य संस्था द्वारा उपयोग नहीं किया जाएगा, तो हम इसे छात्र वर्ग के अंदर घोंसला बना सकते हैं, लेकिन एंटिटी फ्रेमवर्क का यह पूर्व संस्करण नेस्टेड प्रकारों को स्वीकार नहीं करता है।

पुराने संस्करण में, आप मॉडल को फिर से बनाते हैं, न केवल प्रकार को मान्यता प्राप्त नहीं है, बल्कि इसलिए कि यह वहां नहीं है, संपत्ति भी नहीं है, इसलिए एंटिटी फ्रेमवर्क व्यक्तिगत प्रकार को बिल्कुल भी जारी नहीं रखेगा।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
	
   public DateTime EnrollmentDate { get; set; }
   public Person Identity { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }

   public class Person {

      public Person(string fatherName, DateTime birthDate) {
         FatherName = fatherName;
         BirthDate = birthDate;
      }

      public string FatherName { get; set; }
      public DateTime BirthDate { get; set; }
   }
}

एंटिटी फ्रेमवर्क 6 के साथ, नेस्टेड संस्थाओं और जटिल प्रकारों को मान्यता दी जाती है। उपरोक्त कोड में, आप देख सकते हैं कि व्यक्ति छात्र वर्ग के भीतर नेस्टेड है।

जब आप एंटिटी फ्रेमवर्क पावर टूल का उपयोग करते हैं, तो यह दिखाने के लिए कि एंटिटी फ्रेमवर्क इस बार मॉडल की व्याख्या कैसे करता है, वहां सही पहचान संपत्ति और व्यक्ति जटिल प्रकार होता है। इसलिए एंटिटी फ्रेमवर्क उस डेटा को बनाए रखेगा।

अब आप देख सकते हैं कि आइडेंटिटी एक नेस्टेड एंटिटी टाइप है, जिसे एंटिटी फ्रेमवर्क 6 से पहले सपोर्ट नहीं किया गया था।

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