(PHP 5 >= 5.1.0, PHP 7, PHP 8, PECL pdo >= 0.1.0)
PDO::__construct — Создаёт экземпляр PDO, который предоставляет соединение с базой данных
$dsn
,$username
= null
,$password
= null
,$options
= null
Метод создаёт экземпляр PDO, который предоставляет подключение к требуемой базе данных.
dsn
Имя источника данных или имя DSN, которое содержит информацию, которая требуется для подключения к базе данных.
В общем, имя DSN состоит из имени драйвера PDO, за которым следует двоеточие и специфический синтаксис подключения драйвера PDO. Дополнительную информацию даёт раздел «Документация по специфическим драйверам PDO».
Аргументы для параметра dsn
,
чтобы создать соединение с базой данных,
указывают тремя способами:
Параметр dsn
содержит полное имя DSN.
Параметр dsn
состоит из строки uri:
за которым идёт URI, который определяет расположение файла, который содержит
строку DSN. Идентификатор URI указывает на локальный файл или удалённый URL.
uri:file:///path/to/dsnfile
Параметр dsn
состоит из имени
name
, которое соответствует параметру
pdo.dsn.
в файле php.ini,
который определяет строку DSN-имени.
name
Замечание:
Псевдоним требуется определять в файле 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);
?>