From a8d9f09faaded6e15cdc1b4c9dee5139b17b7480 Mon Sep 17 00:00:00 2001 From: Sergei Morozov Date: Fri, 10 Jul 2020 23:12:36 -0700 Subject: [PATCH] Update architecture documentation --- docs/en/reference/architecture.rst | 55 +++++++++++++----------------- 1 file changed, 23 insertions(+), 32 deletions(-) diff --git a/docs/en/reference/architecture.rst b/docs/en/reference/architecture.rst index 5f14c52507a..c7127553ccd 100644 --- a/docs/en/reference/architecture.rst +++ b/docs/en/reference/architecture.rst @@ -1,50 +1,41 @@ Architecture ============ -As already said, the DBAL is a thin layer on top of PDO. PDO itself -is mainly defined in terms of 2 classes: ``PDO`` and -``PDOStatement``. The equivalent classes in the DBAL are -``Doctrine\DBAL\Connection`` and ``Doctrine\DBAL\Statement``. A -``Doctrine\DBAL\Connection`` wraps a -``Doctrine\DBAL\Driver\Connection`` and a -``Doctrine\DBAL\Statement`` wraps a -``Doctrine\DBAL\Driver\Statement``. - -``Doctrine\DBAL\Driver\Connection`` and -``Doctrine\DBAL\Driver\Statement`` are just interfaces. These -interfaces are implemented by concrete drivers. For all PDO based -drivers, ``PDO`` and ``PDOStatement`` are the implementations of -these interfaces. Thus, for PDO-based drivers, a -``Doctrine\DBAL\Connection`` wraps a ``PDO`` instance and a -``Doctrine\DBAL\Statement`` wraps a ``PDOStatement`` instance. - -What does a ``Doctrine\DBAL\Connection`` or a -``Doctrine\DBAL\Statement`` add to the underlying driver +The DBAL consists of two layers: drivers and a wrapper. Each layer +is mainly defined in terms of 3 components: ``Connection``, +```Statement`` and ``Result``. +A ``Doctrine\DBAL\Connection`` wraps a ``Doctrine\DBAL\Driver\Connection``, +a ``Doctrine\DBAL\Statement`` wraps a ``Doctrine\DBAL\Driver\Statement`` +and a ``Doctrine\DBAL\Result`` wraps a ``Doctrine\DBAL\Driver\Result``. + +``Doctrine\DBAL\Driver\Connection``, ``Doctrine\DBAL\Driver\Statement`` +and ``Doctrine\DBAL\Driver\Result`` are just interfaces. +These interfaces are implemented by concrete drivers. + +What do the wrapper components add to the underlying driver implementations? The enhancements include SQL logging, events and control over the transaction isolation level in a portable manner, among others. -A DBAL driver is defined to the outside in terms of 3 interfaces: -``Doctrine\DBAL\Driver``, ``Doctrine\DBAL\Driver\Connection`` and -``Doctrine\DBAL\Driver\Statement``. The latter two resemble (a -subset of) the corresponding PDO API. - -A concrete driver implementation must provide implementation -classes for these 3 interfaces. +Apart from the three main components, a DBAL driver should also provide +an implementation of the ``Doctrine\DBAL\Driver`` interface that +implements the logic of translation of the DBAL connection parameters +to the ones specific to the given driver and provides factory methods +for the driver-specific components like Platform, SchemaManager +and ExceptionConverter. The DBAL is separated into several different packages that -perfectly separate responsibilities of the different RDBMS layers. +separate responsibilities of the different RDBMS layers. Drivers ------- -The drivers abstract a PHP specific database API by enforcing two +The drivers abstract a PHP specific database API by enforcing three interfaces: - ``\Doctrine\DBAL\Driver\Connection`` - ``\Doctrine\DBAL\Driver\Statement`` - -The above two interfaces require exactly the same methods as PDO. +- ``\Doctrine\DBAL\Driver\Result`` Platforms --------- @@ -55,8 +46,8 @@ features a platform supports. The denominator of what a database platform has to publish to the userland, to be fully supportable by Doctrine. This includes the SchemaTool, Transaction Isolation and many other features. The -Database platform for MySQL for example can be used by all 3 MySQL -extensions, PDO, Mysqli and ext/mysql. +Database platform for MySQL for example can be used by multiple +MySQL extensions: pdo_mysql and mysqli. Logging -------