PHPerKaigi 2025

PDO::getAttribute

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

PDO::getAttribute Получает атрибут соединения с базой данных

Описание

public PDO::getAttribute(int $attribute): mixed

Эта функция возвращает значение атрибута соединения с базой данных. Чтобы получить атрибуты объекта PDOStatement, обращаются к методу PDOStatement::getAttribute().

Обратите внимание, что не все комбинации «база данных/драйвер» поддерживают все атрибуты соединения с базой данных.

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

attribute

Одна из констант PDO::ATTR_*. Список общих атрибутов, применяемых к подключениям к базе данных:

  • PDO::ATTR_AUTOCOMMIT
  • PDO::ATTR_CASE
  • PDO::ATTR_CLIENT_VERSION
  • PDO::ATTR_CONNECTION_STATUS
  • PDO::ATTR_DRIVER_NAME
  • PDO::ATTR_ERRMODE
  • PDO::ATTR_ORACLE_NULLS
  • PDO::ATTR_PERSISTENT
  • PDO::ATTR_PREFETCH
  • PDO::ATTR_SERVER_INFO
  • PDO::ATTR_SERVER_VERSION
  • PDO::ATTR_TIMEOUT

Некоторые драйверы могут использовать дополнительные, характерные для этого драйвера, атрибуты. Обратите внимание, что атрибуты драйвера не должны быть использованы с другими драйверами.

Возвращаемые значения

Возвращает значение атрибута запрошенного PDO (при успешном вызове). Неудачный вызов возвращает null.

Ошибки

Метод PDO::getAttribute() может выбросить исключение PDOException, когда базовый драйвер не поддерживает запрошенный в параметре attribute атрибут.

Примеры

Пример #1 Получение атрибутов соединения с базой данных

<?php
$conn
= new PDO('odbc:sample', 'db2inst1', 'ibmdb2');
$attributes = array(
"AUTOCOMMIT", "ERRMODE", "CASE", "CLIENT_VERSION", "CONNECTION_STATUS",
"ORACLE_NULLS", "PERSISTENT", "PREFETCH", "SERVER_INFO", "SERVER_VERSION",
"TIMEOUT"
);

foreach (
$attributes as $val) {
echo
"PDO::ATTR_$val: ";
echo
$conn->getAttribute(constant("PDO::ATTR_$val")) . "\n";
}
?>

Смотрите также

Добавить

Примечания пользователей 2 notes

up
5
Phil Hilton
6 years ago
Better example that handles unsupported attributes gracefully:

<?php

$conn
= new PDO( 'odbc:sample', 'db2inst1', 'ibmdb2' );
$conn->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );

$attributes = array(
"AUTOCOMMIT", "ERRMODE", "CASE", "CLIENT_VERSION", "CONNECTION_STATUS",
"ORACLE_NULLS", "PERSISTENT", "PREFETCH", "SERVER_INFO", "SERVER_VERSION",
"TIMEOUT"
);

foreach (
$attributes as $val ) {
echo
"PDO::ATTR_$val: ";
try {
echo
$conn->getAttribute( constant( "PDO::ATTR_$val" ) ) . "\n";
} catch (
PDOException $e ) {
echo
$e->getMessage() . "\n";
}
}

?>
up
0
Robert Parham
9 years ago
Oracle does not have the following attributes:

PDO::ATTR_CONNECTION_STATUS: SQLSTATE[IM001]: Driver does not support this function: driver does not support that attribute
PDO::ATTR_PREFETCH: SQLSTATE[IM001]: Driver does not support this function: driver does not support that attribute
PDO::ATTR_TIMEOUT: SQLSTATE[IM001]: Driver does not support this function: driver does not support that attribute

The rest work fine.
To Top