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