Entity Framework - dziedziczenie

Dziedziczenie umożliwia tworzenie złożonych modeli, które lepiej odzwierciedlają sposób myślenia programistów, a także zmniejszają ilość pracy wymaganej do interakcji z tymi modelami. Dziedziczenie używane z encjami służy temu samemu celowi, co dziedziczenie używane z klasami, więc programiści znają już podstawy działania tej funkcji.

Przyjrzyjmy się poniższemu przykładowi i utworzymy nowy projekt aplikacji konsoli.

Step 1 - Dodaj model danych jednostki ADO.NET, klikając prawym przyciskiem myszy nazwę projektu i wybierając opcję Dodaj → Nowy element…

Step 2 - Dodaj jedną jednostkę i nazwij ją Osoba, wykonując wszystkie kroki wymienione w rozdziale Pierwsze podejście do modelu.

Step 3 - Dodaj właściwości skalarne, jak pokazano na poniższym obrazku.

Step 4 - Dodamy jeszcze dwie jednostki Student i Teacher, który odziedziczy właściwości z tabeli osób.

Step 5 - Teraz dodaj jednostkę ucznia i wybierz osobę z pola wyboru typu podstawowego, jak pokazano na poniższym obrazku.

Step 6 - Podobnie dodaj jednostkę Nauczyciela.

Step 7 - Teraz dodaj właściwość skalarną EnrollmentDate do jednostki studenta i właściwość HireDate do jednostki Nauczyciel.

Step 8 - Przejdźmy dalej i wygenerujmy bazę danych.

Step 9 - Kliknij prawym przyciskiem myszy powierzchnię projektową i wybierz opcję Generuj bazę danych z modelu…

Step 10- Aby utworzyć nową bazę danych, kliknij Nowe połączenie… Otworzy się następujące okno dialogowe. Kliknij OK.

Step 11- Kliknij Zakończ. Spowoduje to dodanie pliku * .edmx.sql do projektu. Skrypty DDL można wykonywać w programie Visual Studio, otwierając plik .sql. Teraz kliknij prawym przyciskiem myszy i wybierz Wykonaj.

Step 12 - Przejdź do eksploratora serwera, a zobaczysz, że baza danych jest tworzona z trzema określonymi tabelami.

Step 13 - Możesz również zobaczyć, że następujące klasy domen są również generowane automatycznie.

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

Poniżej znajduje się klasa Context.

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

Dodajmy kilku Uczniów i Nauczycieli do bazy danych, a następnie pobierzmy ją z bazy danych.

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

W bazie danych są dodawani uczniowie i nauczyciele. Aby pobrać uczniów i nauczyciela, plikOfType należy użyć metody, która zwróci Ucznia i Nauczyciela związanego z określonym działem.

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();

W pierwszym zapytaniu, gdy użyjesz OfType <Student> (), nie będziesz mieć dostępu do HireDate, ponieważ właściwość HireDate jest częścią Teacher Entity i podobnie właściwość EnrollmentDate nie będzie dostępna, gdy użyjesz OfType <Teacher> ()

Po wykonaniu powyższego kodu otrzymasz następujący wynik -

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

Zalecamy wykonanie powyższego przykładu krok po kroku w celu lepszego zrozumienia.