इकाई ढांचा - वंशानुक्रम

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

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

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
*****************************************************************

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