PDO::__construct

(PHP 5 >= 5.1.0, PHP 7, PHP 8, PECL pdo >= 0.1.0)

PDO::__construct Создаёт экземпляр PDO, который предоставляет соединение с базой данных

Описание

public PDO::__construct(
    string $dsn,
    ?string $username = null,
    ?string $password = null,
    ?array $options = null
)

Метод создаёт экземпляр PDO, который предоставляет подключение к требуемой базе данных.

Список параметров

dsn

Имя источника данных или имя DSN, которое содержит информацию, которая требуется для подключения к базе данных.

В общем, имя DSN состоит из имени драйвера PDO, за которым следует двоеточие и специфический синтаксис подключения драйвера PDO. Дополнительную информацию даёт раздел «Документация по специфическим драйверам PDO».

Аргументы для параметра dsn, чтобы создать соединение с базой данных, указывают тремя способами:

Вызов драйвера

Параметр dsn содержит полное имя DSN.

Вызов URI-идентификатора

Параметр dsn состоит из строки uri: за которым идёт URI, который определяет расположение файла, который содержит строку DSN. Идентификатор URI указывает на локальный файл или удалённый URL.

uri:file:///path/to/dsnfile

Совмещение имён

Параметр dsn состоит из имени name, которое соответствует параметру pdo.dsn.name в файле php.ini, который определяет строку DSN-имени.

Замечание:

Псевдоним требуется определять в файле php.ini, но не в файлах .htaccess или httpd.conf

username

Имя пользователя для строки DSN. Этот параметр необязателен для ряда драйверов PDO.

password

Пароль для строки DSN. Этот параметр необязателен для ряда драйверов PDO.

options

Массив ключ=>значение, которые специфичны для драйвера настроек подключения.

Ошибки

Метод PDO::__construct() выбрасывает исключение PDOException, если попытка подключения к запрашиваемой базе данных завершается с ошибкой, независимо от того, какой флаг PDO::ATTR_ERRMODE установили.

Примеры

Пример #1 Создать экземпляр PDO через вызов драйвера

<?php

$dsn
= 'mysql:dbname=testdb;host=127.0.0.1';
$user = 'dbuser';
$password = 'dbpass';

$dbh = new PDO($dsn, $user, $password);

?>

Пример #2 Создать экземпляр PDO через вызов URI

В следующем примере предполагается, что файл /usr/local/dbconnect существует с правами доступа, которые разрешают PHP прочитать файл. Файл содержит PDO DSN для подключения к базе данных DB2 через драйвер PDO_ODBC:

odbc:DSN=SAMPLE;UID=john;PWD=mypass

PHP-скрипт создаёт подключение к базе данных путём простой передачи параметра uri:, который указывает на файл идентификатора URI:

<?php

$dsn
= 'uri:file:///usr/local/dbconnect';
$user = '';
$password = '';

$dbh = new PDO($dsn, $user, $password);

?>

Пример #3 Создать экземпляр PDO через псевдоним

В следующем примере предполагается, что файл php.ini содержит следующую запись, которая разрешает подключиться к базе данных MySQL только через псевдоним mydb:

[PDO]
     pdo.dsn.mydb="mysql:dbname=testdb;host=localhost"
<?php

$dsn
= 'mydb';
$user = '';
$password = '';

$dbh = new PDO($dsn, $user, $password);

?>