„Doctrine (PHP)“ – Versionsunterschied
[gesichtete Version] | [gesichtete Version] |
K r2.7.1) (Bot: Ergänze: es:Doctrine (PHP) |
K Abschnittlink korrigiert |
||
(34 dazwischenliegende Versionen von 31 Benutzern werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
{{Infobox Software |
{{Infobox Software |
||
| Name = Doctrine |
| Name = Doctrine |
||
| Logo = |
|||
⚫ | |||
| Screenshot = |
|||
⚫ | |||
| Beschreibung = |
|||
| Maintainer = |
|||
| Hersteller = |
|||
| Erscheinungsjahr = |
|||
⚫ | |||
⚫ | |||
| AktuelleVorabVersion = 3.0 |
|||
| AktuelleVorabVersionFreigabeDatum = |
|||
| Betriebssystem = |
|||
| Programmiersprache = [[PHP]] |
| Programmiersprache = [[PHP]] |
||
| Kategorie= [[Framework]], [[Objektrelationale Abbildung|Objektrelationaler Mapper]] |
| Kategorie = [[Framework]], [[Objektrelationale Abbildung|Objektrelationaler Mapper]] |
||
| Lizenz = [[ |
| Lizenz = [[MIT-Lizenz]] |
||
| Deutsch = |
|||
| Website = [ |
| Website = [https://www.doctrine-project.org/ www.doctrine-project.org] |
||
| Dateien = |
|||
}} |
}} |
||
'''Doctrine''' oder ''' |
Das '''Doctrine Project''' oder kurz '''Doctrine''' ist ein [[Framework]], das die Möglichkeit der [[Objektrelationale Abbildung|objektrelationalen Abbildung]] ({{enS|''object-relational mapping''}}, ''ORM'') sowie eine [[Datenbankabstraktionsschicht]] ({{enS|''database abstraction layer''}}) für [[PHP]] ab Version 5.3 bereitstellt. Dadurch ist ein vereinfachter Zugriff auf verschiedene Datenbanktypen (z. B. [[MySQL]] oder [[Microsoft SQL Server]]) möglich, als dies mit reinem PHP möglich wäre. Doctrine orientiert sich an [[Hibernate (Framework)|Hibernate]], einem ähnlichen Projekt für [[Java (Programmiersprache)|Java]]. |
||
Datenbankabfragen können in der Doctrine-eigenen Zwischensprache ''Doctrine Query Language'' (DQL) formuliert werden. Der objektorientierte Ansatz ermöglicht ein abstraktes Arbeiten unabhängig von der verwendeten Datenbank. Auch können Datenbankinhalte objektorientiert verwaltet werden, ohne einen [[Wrapper (Software)|Wrapper]] dafür bereitzustellen. Die objektrelationale Funktionalität wird hier den Objekten selbst zugewiesen, ohne dass eine aufwändige Programmierung in PHP notwendig ist. |
|||
Da der DBAL mehrere Datenbankserver ansprechen kann, umfasst DQL nur die Menge an SQL-Funktionalität, die in allen von Doctrine unterstützten SQL-Systemen verfügbar sind. Dadurch sind beispielsweise komplexere [[SQL#Inner|Joins]] nicht immer möglich. Zudem hat Doctrine strikte Einschränkungen bezüglich des Aufbaus der Datenbanken. So muss z. B. jede Tabelle zwingend einen [[Schlüssel (Datenbank)|Primärschlüssel]] aufweisen. Dadurch kann es insbesondere mit großen Bestandsdatenbanken, die vorher mit regulärem SQL gepflegt wurden, zu Problemen kommen. |
|||
⚫ | |||
⚫ | |||
Wenn als Beispiel ein neues Benutzerobjekt in der Datenbank erstellt werden soll, könnte das in PHP geschrieben wie folgt aussehen: |
Wenn als Beispiel ein neues Benutzerobjekt in der Datenbank erstellt werden soll, könnte das in PHP geschrieben wie folgt aussehen: |
||
< |
<syntaxhighlight lang="php"> |
||
$user = new User(); |
$user = new User(); |
||
$user-> |
$user->setName("Max"); |
||
$user-> |
$user->setPassword("test"); |
||
$entityManager->persist($user); |
$entityManager->persist($user); |
||
$entityManager->flush(); |
|||
echo "Der Benutzer mit der ID $user-> |
echo "Der Benutzer mit der ID ".$user->getId()." wurde erfolgreich hinzugefügt."; |
||
</source> |
|||
</syntaxhighlight> |
|||
Hierbei wird der sogenannte [[Entity Manager]] von Doctrine angewiesen, ein Objekt ([[Model View Controller# |
Hierbei wird der sogenannte [[Entity Manager]] von Doctrine angewiesen, ein Objekt ([[Model View Controller#Modell (model)|Model]]) zu speichern. Der Entity Manager verwaltet Models und dient als Schnittstelle zur Datenbank. |
||
== Weblinks == |
== Weblinks == |
||
⚫ | |||
* [http://www.doctrine-forum.de doctrine-forum.de] deutschsprachiges Forum |
|||
⚫ | |||
[[Kategorie:Bibliothek (Programmierung)]] |
|||
[[Kategorie:Skriptsprache PHP]] |
|||
[[ |
[[Kategorie:PHP-Bibliothek]] |
||
[[en:Doctrine (PHP)]] |
|||
[[es:Doctrine (PHP)]] |
|||
[[fr:Doctrine (ORM)]] |
|||
[[pl:Doctrine]] |
|||
[[ru:Doctrine]] |
Aktuelle Version vom 17. Juni 2023, 19:40 Uhr
Doctrine | |
---|---|
Basisdaten
| |
Erscheinungsjahr | 13. April 2006 |
Aktuelle Version | 2.10.3 (3. Dezember 2021) |
Aktuelle Vorabversion | 3.0 |
Betriebssystem | Plattformunabhängig |
Programmiersprache | PHP |
Kategorie | Framework, Objektrelationaler Mapper |
Lizenz | MIT-Lizenz |
www.doctrine-project.org |
Das Doctrine Project oder kurz Doctrine ist ein Framework, das die Möglichkeit der objektrelationalen Abbildung (englisch object-relational mapping, ORM) sowie eine Datenbankabstraktionsschicht (englisch database abstraction layer) für PHP ab Version 5.3 bereitstellt. Dadurch ist ein vereinfachter Zugriff auf verschiedene Datenbanktypen (z. B. MySQL oder Microsoft SQL Server) möglich, als dies mit reinem PHP möglich wäre. Doctrine orientiert sich an Hibernate, einem ähnlichen Projekt für Java.
Datenbankabfragen können in der Doctrine-eigenen Zwischensprache Doctrine Query Language (DQL) formuliert werden. Der objektorientierte Ansatz ermöglicht ein abstraktes Arbeiten unabhängig von der verwendeten Datenbank. Auch können Datenbankinhalte objektorientiert verwaltet werden, ohne einen Wrapper dafür bereitzustellen. Die objektrelationale Funktionalität wird hier den Objekten selbst zugewiesen, ohne dass eine aufwändige Programmierung in PHP notwendig ist.
Da der DBAL mehrere Datenbankserver ansprechen kann, umfasst DQL nur die Menge an SQL-Funktionalität, die in allen von Doctrine unterstützten SQL-Systemen verfügbar sind. Dadurch sind beispielsweise komplexere Joins nicht immer möglich. Zudem hat Doctrine strikte Einschränkungen bezüglich des Aufbaus der Datenbanken. So muss z. B. jede Tabelle zwingend einen Primärschlüssel aufweisen. Dadurch kann es insbesondere mit großen Bestandsdatenbanken, die vorher mit regulärem SQL gepflegt wurden, zu Problemen kommen.
Anwendungsbeispiel
[Bearbeiten | Quelltext bearbeiten]Wenn als Beispiel ein neues Benutzerobjekt in der Datenbank erstellt werden soll, könnte das in PHP geschrieben wie folgt aussehen:
$user = new User();
$user->setName("Max");
$user->setPassword("test");
$entityManager->persist($user);
$entityManager->flush();
echo "Der Benutzer mit der ID ".$user->getId()." wurde erfolgreich hinzugefügt.";
Hierbei wird der sogenannte Entity Manager von Doctrine angewiesen, ein Objekt (Model) zu speichern. Der Entity Manager verwaltet Models und dient als Schnittstelle zur Datenbank.