<?php namespace Doctrine\DBAL\Driver\PDOMySql; use Doctrine\DBAL\Driver\AbstractMySQLDriver; use Doctrine\DBAL\Driver\PDO\Connection; use PDO; /** * PDO MySql driver. */ class Driver extends AbstractMySQLDriver { /** * {@inheritdoc} */ public function connect(array $params) { $driverOptions = $params['driver_options'] ?? []; if (! empty($params['persistent'])) { $driverOptions[PDO::ATTR_PERSISTENT] = true; } return new Connection( $this->constructPdoDsn($params), $params['user'] ?? '', $params['password'] ?? '', $driverOptions ); } /** * Constructs the MySql PDO DSN. * * @param mixed[] $params * * @return string The DSN. */ protected function constructPdoDsn(array $params) { $dsn = 'mysql:'; if (isset($params['host']) && $params['host'] !== '') { $dsn .= 'host=' . $params['host'] . ';'; } if (isset($params['port'])) { $dsn .= 'port=' . $params['port'] . ';'; } if (isset($params['dbname'])) { $dsn .= 'dbname=' . $params['dbname'] . ';'; } if (isset($params['unix_socket'])) { $dsn .= 'unix_socket=' . $params['unix_socket'] . ';'; } if (isset($params['charset'])) { $dsn .= 'charset=' . $params['charset'] . ';'; } return $dsn; } }