इकाई ढांचा - प्रवासन
एंटिटी फ्रेमवर्क 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 में काम करेगा।