Configuration¶
The configuration of Doctrine DBAL for TYPO3 is about specifying the single
database endpoints and passing the connection credentials. The framework
supports the parallel usage of multiple database connections, a specific
connection is mapped depending on its table name. The table space can be seen as
a transparent layer that determines which specific connection is chosen for a
query to a single or a group of tables: It allows "swapping out" single tables
from the Default
connection to point them to a different database endpoint.
As with other central configuration options, the database endpoint and mapping
configuration is done in config/
and ends up in
$GLOBALS
after the Core bootstrap. The specific sub-array is
$GLOBALS
.
Example: one connection¶
A typical basic example using only the Default
connection with a single
database endpoint:
// [...]
'DB' => [
'Connections' => [
'Default' => [
'charset' => 'utf8',
'dbname' => 'theDatabaseName',
'driver' => 'mysqli',
'host' => 'theHost',
'password' => 'theConnectionPassword',
'port' => 3306,
'user' => 'theUser',
],
],
],
// [...]
Remarks:
- The
Default
connection must be configured, this can not be left out or renamed. - For the
mysqli
driver: If thehost
is set tolocalhost
and if the default PHP options in this area are not changed, the connection will be socket-based. This saves a little overhead. To force a TCP/IP-based connection even forlocalhost
, the IPv4 address127.
or IPv6 address0. 0. 1 ::
respectively must be used as1/ 128 host
value. - The connection options are passed to Doctrine DBAL without much manipulation from TYPO3 side. Please refer to the doctrine connection docs for a full overview of the settings.
- If the
charset
option is not specified, it defaults toutf8
. - The option
wrapper
is used by TYPO3 to insert the extended Connection classClass \TYPO3\
as main facade around Doctrine DBAL.CMS\ Core\ Database\ Connection
Example: two connections¶
Another example with two connections, where the be_
table is
mapped to a different endpoint:
// [...]
'DB' => [
'Connections' => [
'Default' => [
'charset' => 'utf8',
'dbname' => 'default_dbname',
'driver' => 'mysqli',
'host' => 'default_host',
'password' => '***',
'port' => 3306,
'user' => 'default_user',
],
'Sessions' => [
'charset' => 'utf8mb4',
'driver' => 'mysqli',
'dbname' => 'sessions_dbname',
'host' => 'sessions_host',
'password' => '***',
'port' => 3306,
'user' => 'some_user',
],
],
'TableMapping' => [
'be_sessions' => 'Sessions',
]
],
// [...]
Remarks:
- The array key
Sessions
is just a name. It can be different, but it is good practice to give it a useful, descriptive name. - It is possible to map multiple tables to a different endpoint by adding
further table name / connection name pairs to
Table
.Mapping - However, this "connection per table" approach is limited: In the above
example, if a join query is executed that spans different connections, an
exception will be thrown. It is up to the administrator to group the
affected tables to the same connection in those cases, or a developer should
implement fallback logic to suppress the
join
.()
Attention
The TYPO3 installer supports only a single MariaDB or MySQL connection at the moment.