CakeFest 2024: The Official CakePHP Conference

PDO_MYSQL DSN

(PECL PDO_MYSQL >= 0.1.0)

PDO_MYSQL DSNСоединение с базой данных MySQL

Описание

Имя источника данных (Data Source Name, или DSN) PDO_MYSQL состоит из следующих элементов:

DSN префикс

DSN-префикс — это mysql:.

host

Имя хоста сервера баз данных.

port

Номер порта, который слушает сервер баз данных.

dbname

Имя базы данных.

unix_socket

Сокет MySQL Unix (нельзя указывать совместно с host или port).

charset

Кодировка. Дополнительная информация дана в разделе «Кодировки».

Примеры

Пример #1 Примеры DSN для драйвера PDO_MYSQL

Следующий пример показывает DSN-имя драйвера PDO_MYSQL для соединения с базой данных MySQL:

mysql:host=localhost;dbname=testdb
Более полные примеры:
mysql:host=localhost;port=3307;dbname=testdb
mysql:unix_socket=/tmp/mysql.sock;dbname=testdb

Примечания

Замечание: Только Unix:

Если имя хоста установлено как «localhost», то соединение выполняется через сокет домена. Если драйвер PDO_MYSQL скомпилирован с модулем libmysqlclient, то файла сокета будет находиться в папке, скомпилированной libmysqlclient. Если PDO_MYSQL скомпилирован с модулем mysqlnd, сокет по умолчанию можно установить через директиву pdo_mysql.default_socket.

add a note

User Contributed Notes 8 notes

up
37
codeslinger at compsalot dot com
15 years ago
I have tested this and found that the "dbname" field is optional. Which is a good thing if you must first create the db.

After creating a db be sure to exec a "use dbname;" command, or else use fully specified table references.
up
7
rhian
7 years ago
xwisdom made a mistake in his comment and got it backwards, correction below:

If you are having problems accessing a remote MYSQL database, the solution is to make sure that you add a white-space after "mysql:"

Change this...:
mysql:host=remote;

...to this:
mysql: host=remote;

See original solution here:
http://stackoverflow.com/a/25432156
up
0
anrdaemon at yandex dot ru
2 years ago
Wrappers may add support for extra parameters in the DSN, which are ignored by PDO itself, but facilitate more fine-grained connection setup.

F.e. localization (particularly LC_TIME) and timezones support.

https://github.com/AnrDaemon/library-php/blob/335e9e58f22cca8c185b35cf201ad0a367ae4c9f/src/Wrappers/PDOMysql.php#L54-L69
up
0
FireDev
4 years ago
The best way for me

$bdd= new PDO("mysql:host=localhost;dbname=test_db;charset=UTF8", "username", "password");
$bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
up
0
siguza at siguza dot net dot IGNORETHIS
9 years ago
It should be noted that unix_socket can also be used for named pipes under Windows.

<?php
$pipeName
= 'my_awesome_pipe';
$username = 'username';
$password = 'password';
$dbh = new PDO('mysql:unix_socket='.$pipeName, $username, $password);
?>
up
-1
divinity76 at gmail dot com
4 years ago
here is the example i prefer myself, in my opinion, this is almost always "the correct way" to do it:
<?php

$db
= new \PDO('mysql:host=localhost;dbname=testdb;charset=utf8mb4', 'username', 'password', array(
\PDO::ATTR_EMULATE_PREPARES => false,
\PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION
));
up
-6
yuqiangliu at outlook dot com
4 years ago
$options = array(
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
);

SET NAMES utf8 is equivalent to

SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;
up
-15
xwisdom at gmail dot com
8 years ago
If you are having problems accessing a remote MYSQL database, the solution is to make sure that you remove any white-space after "mysql:"

Change this...:
mysql: host=remote;

...to this:
mysql:host=remote;

See original solution here:
http://stackoverflow.com/a/25432156
To Top