NHibernate - Übersicht
In diesem Kapitel werden wir diskutieren, was NHibernate ist, welche Plattformen es implementieren kann, welche Vorteile es hat und welche anderen Aspekte damit verbunden sind.
Was ist NHibernate?
NHibernate ist ein ausgereifter, objektbezogener Open Source-Mapper für das .NET-Framework. Es ist aktiv entwickelt, voll funktionsfähig und wird in Tausenden von erfolgreichen Projekten verwendet. Es ist darauf aufgebautADO.NET und die aktuelle Version ist NHibernate 4.0.4.
NHibernate ist ein objektrelationaler Open-Source-Mapper für .NET und wird unter der GNU Lesser General Public License.
Es basiert auf Hibernate, einem beliebten objektrelationalen Java-Mapper, und verfügt über eine sehr ausgereifte und aktive Codebasis.
Es bietet einen Rahmen für die Zuordnung eines objektorientierten Domänenmodells zu einer herkömmlichen relationalen Datenbank.
NHibernate wurde von gestartet Tom Barrett und dieses Projekt gibt es seit Februar 2003, was ihr erstes Engagement war.
Es ist ein großes Projekt und bietet viele Funktionen.
Da ist ein NuGet package verfügbar, was das Hinzufügen zu einem Projekt sehr einfach macht.
Warum NHibernate?
Jetzt ist die Frage, warum wir brauchen object-relational mappers? Es liegt daran, dass es eine Trennung zwischen der Objektwelt und der relationalen Welt gibt.
In der Objektwelt basiert alles auf objects;; Wir nannten Objekte jene Dinge, die unsere Daten haben.
Die relationale Welt ist alle satzbasiert und wir haben es mit Tabellen und Zeilen zu tun, die sich von der Objektwelt unterscheiden.
In der Objektwelt haben wir unidirectional associations. Wenn ein Kunde einen Zeiger auf eine Bestellung hat, bedeutet dies nicht unbedingt, dass eine Bestellung einen Zeiger zurück auf einen Kunden hat, möglicherweise oder nicht.
In der relationalen Welt sind alle Assoziationen bidirectional und es kann durch einen Fremdschlüssel erfolgen.
Alle Assoziationen sind von Natur aus bidirektional. Wenn wir uns also mit objektrelationaler Zuordnung befassen, müssen wir uns auch mit dieser Trennung befassen.
In der Objektwelt arbeiten wir mit Zeigern, die unidirektional sind, während wir in der relationalen Welt Fremdschlüssel haben, die von Natur aus bidirektional sind.
Die Objektwelt hat diesen Begriff der Vererbung, bei dem ein Fahrzeug eine Reihe verschiedener Unterklassen haben kann, so dass ein Auto ein Fahrzeugtyp ist, ein Boot ein Fahrzeugtyp ist und ein Sportwagen ein Fahrzeugtyp ist, diese Arten von Vererbungsbeziehungen.
Die relationale Welt hat diesen Begriff der Vererbung nicht.
Kartierung
Wie ordnen wir all dies zu? disjoint relationships?Dieses Mapping-Konzept stammt aus dem objektrelationalen Mapper. Es gibt hauptsächlich drei Dinge zu verstehen, wie in der folgenden Abbildung gezeigt.
In Ihrer Anwendung benötigen Sie Klassendefinitionen, bei denen es sich normalerweise um C # -Code und den .NET-Code handelt, der unsere Klassen darstellt, z. B. Mitarbeiterklasse, Kundenklasse, Auftragsklasse usw.
Unten sehen Sie ein Datenbankschema, das unser ist Data Definition Language in einer relationalen Datenbank, die angibt, wie eine Kundentabelle aussieht, wie eine Mitarbeitertabelle aussieht.
Dazwischen befinden sich die Mapping-Metadaten, die dem objektrelationalen Mapper mitteilen, wie er in Zeilen und Spalten und Fremdschlüsselbeziehungen von der Objektwelt in C # in die Datenbankwelt übersetzen soll.
Diese Zuordnungsmetadaten können auf verschiedene Arten dargestellt werden, und wir werden eine Reihe dieser verschiedenen Arten untersuchen, die für NHibernate-Anwendungen am typischsten sind.
Es wird vertreten durch HBM (Hibernate Mapping) Dateien, die XML-Dateien sind.
Datenbank unterstützt
NHibernate unterstützt eine Vielzahl unterschiedlicher Datenbanken. Auf jede vorhandene relationale Datenbank kann auf NHibernate zugegriffen werden.
SQL Server ist die primär unterstützte Datenbank. Dies ist das, was die meisten Entwickler während der Entwicklung verwenden. Es ist wahrscheinlich die häufigste.
Es auch works very well with Oracle.
Es unterstützt auch DB2, Firebird, MySQL, PostgreSQL und SQL Lite
Es hat auch ODBC and OLEDB drivers.