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