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.