(PECL ibm_db2 >= 1.0.0)
db2_connect — Возвращает соединение с базой данных
$database
,$username
,$password
,$options
= []Функция создаёт новое соединение с базой данных IBM DB2 Universal Database, IBM Cloudscape или базой данных Apache Derby.
database
Для каталогизированного соединения с базой данных
параметр database
представляет собой псевдоним базы данных
в клиентском каталоге DB2.
Для некаталогизированного подключения к базе данных
параметр database
представляет собой полную строку
подключения в следующем формате:
DATABASE=database
;HOSTNAME=hostname
;PORT=port
;PROTOCOL=TCPIP;UID=username
;PWD=password
;
где параметры представляют следующие значения:Замечание:
При подключении к БД Db2 на ОС IBM i базовая система вызывает функцию » SQLDriverConnect, которая принимает только имя источника данных DSN, идентификатор пользователя UID и пароль PWD для » строки подключения. Вот так:
DSN=database
;UID=username
;PWD=password
;
database
Имя базы данных.
hostname
Имя хоста или IP-адрес сервера базы данных.
port
Порт TCP/IP, который используется базой данных для принятия запросов.
username
Имя пользователя, под которым выполняется подключение к базе данных.
password
Пароль, с которым выполняется подключение к базе данных.
username
Имя пользователя, под которым выполняется подключение к базе данных.
Для некаталогизированных соединений необходимо передать значение null
или пустую строку.
password
Пароль, с которым выполняется подключение к базе данных.
Для некаталогизированных соединений необходимо передать значение null
или пустую строку.
options
Ассоциативный массив параметров подключения, которые влияют на поведение подключения, в котором допустимые ключи массива включают:
autocommit
Передача значения DB2_AUTOCOMMIT_ON
включает
автоматическую фиксацию (autocommit) для этого дескриптора соединения.
Передача значения DB2_AUTOCOMMIT_OFF
выключает
автоматическую фиксацию (autocommit) для этого дескриптора соединения.
DB2_ATTR_CASE
Передача значения DB2_CASE_NATURAL
указывает,
что имена столбцов возвращаются в естественном регистре.
Передача значения DB2_CASE_LOWER
указывает,
что имена столбцов возвращаются в нижнем регистре.
Передача значения DB2_CASE_UPPER
указывает,
что имена столбцов возвращаются в верхнем регистре.
CURSOR
Передача значения DB2_FORWARD_ONLY
задаёт курсор,
который двигается только вперёд, для ресурса оператора. Данный тип
курсора используется по умолчанию, он поддерживается всеми серверами
баз данных.
Передача значения DB2_SCROLLABLE
задаёт
прокручиваемый курсор для ресурса оператора. Этот режим включает
произвольный доступ к строкам в наборе результатов, но в настоящее
время поддерживается только IBM DB2 Universal Database.
Эта новая опция доступна в модуле ibm_db2 версии 1.7.0 и новее.
trustedcontext
Передача значения DB2_TRUSTED_CONTEXT_ENABLE включает доверенный контекст для этого дескриптора соединения. Этот параметр нельзя установить функцией db2_set_option().
Этот ключ работает только тогда, когда базу данных каталогизировали (даже если база данных локальная) или если укажут полное DSN-имя при создании соединения.
Чтобы каталогизировать базу данных, выполняют следующие команды:
db2 catalog tcpip node loopback remote <SERVERNAME> server <SERVICENAME> db2 catalog database <LOCALDBNAME> as <REMOTEDBNAME> at node loopback db2 "update dbm cfg using svcename <SERVICENAME>" db2set DB2COMM=TCPIP
Эти новые опции ОС i5/OS доступны в модуле ibm_db2 версии 1.5.1 и новее.
i5_lib
Символьное значение, которое указывает библиотеку по умолчанию, которая будет использоваться для разрешения неквалифицированных ссылок на файлы. Это недопустимо, если соединение использует режим именования системы.
i5_naming
Значение DB2_I5_NAMING_ON
включает режим
именования системы DB2 UDB CLI iSeries. Файлы квалифицируются
через слеш (/) в качестве разделителя. Неквалифицированные
файлы разрешаются с использованием списка библиотек для работы.
Значение DB2_I5_NAMING_OFF
выключает режим
именования по умолчанию DB2 UDB CLI, который представляет собой именование SQL.
Файлы квалифицируются через точку (.) в качестве
разделителя. Неквалифицированные файлы разрешаются с использованием
либо библиотеки по умолчанию, либо текущего идентификатора
пользователя.
i5_commit
Атрибут i5_commit
требуется установить перед
вызовом функции db2_connect(). Если значение изменяется
после установки соединения, и соединение установлено
с удалённым источником данных, изменение не вступит в силу до
следующего успешного вызова функции db2_connect()
для дескриптора соединения.
Замечание:
Параметр
ibm_db2.i5_allow_commit
==0 файла php.ini или настройкаDB2_I5_TXN_NO_COMMIT
используется по умолчанию, но может быть изменён через параметрi5_commit
.
DB2_I5_TXN_NO_COMMIT
— Контроль транзакций не
используется.
DB2_I5_TXN_READ_UNCOMMITTED
— Возможны грязные
чтения, неповторяющиеся чтения и фантомы.
DB2_I5_TXN_READ_COMMITTED
— Грязное чтение невозможно.
Возможны неповторяющиеся чтения и фантомы
DB2_I5_TXN_REPEATABLE_READ
— Грязные чтения и
неповторяющиеся чтения невозможны. Возможны фантомы.
DB2_I5_TXN_SERIALIZABLE
— Транзакции сериализуемы.
Грязные чтения, неповторяющиеся чтения и фантомы невозможны.
i5_query_optimize
DB2_FIRST_IO
— Все запросы оптимизированы с целью
максимально быстрого возврата первой страницы вывода. Эта цель
хорошо работает, когда вывод контролируется пользователем, который,
скорее всего, отменит запрос после просмотра первой страницы
выходных данных. Запросы, закодированные с предложением
OPTIMIZE FOR nnn ROWS, учитывают цель, указанную в предложении.
DB2_ALL_IO
— Все запросы оптимизированы с целью
выполнить весь запрос до завершения в кратчайшие сроки. Это хороший
вариант, когда выходные данные запроса записываются в файл или отчёт,
или когда интерфейс ставит выходные данные в очередь. Запросы,
закодированные с предложением OPTIMIZE FOR nnn ROWS, учитывают цель,
указанную в предложении. Это значение по умолчанию.
i5_dbcs_alloc
Значение DB2_I5_DBCS_ALLOC_ON
включает схему
распределения DB2 6X для увеличения размера столбца преобразования DBCS.
Значение DB2_I5_DBCS_ALLOC_OFF
отключает схему
распределения DB2 6X для увеличения размера столбца преобразования DBCS.
Замечание: параметр ibm_db2.i5_dbcs_alloc
==0 файла php.ini
или параметр DB2_I5_DBCS_ALLOC_OFF
— значение
по умолчанию, но его можно изменить через параметр
i5_dbcs_alloc
.
i5_date_fmt
DB2_I5_FMT_ISO
— Используется формат даты
Международной организации по стандартизации ISO (yyyy-mm-dd).
Это значение по умолчанию.
DB2_I5_FMT_USA
— Используется формат даты США
(mm/dd/yyyy).
DB2_I5_FMT_EUR
— Используется европейский формат
даты (dd.mm.yyyy).
DB2_I5_FMT_JIS
— Используется формат даты японского
промышленного стандарта (yyyy-mm-dd).
DB2_I5_FMT_MDY
— Используется формат даты
mm/dd/yyyy.
DB2_I5_FMT_DMY
— Используется формат даты
dd/mm/yyyy.
DB2_I5_FMT_YMD
— Используется формат даты yy/mm/dd.
DB2_I5_FMT_JUL
— Используется юлианский формат
даты (yy/ddd).
DB2_I5_FMT_JOB
— Используется задание по умолчанию.
i5_date_sep
DB2_I5_SEP_SLASH
— В качестве разделителя даты
используется косая черта ( / ). Это значение по умолчанию.
DB2_I5_SEP_DASH
— В качестве разделителя даты
используется дефис ( - ).
DB2_I5_SEP_PERIOD
— В качестве разделителя даты
используется точка ( . ).
DB2_I5_SEP_COMMA
— В качестве разделителя даты
используется запятая ( , ).
DB2_I5_SEP_BLANK
— В качестве разделителя даты
используется пробел.
DB2_I5_SEP_JOB
— Используется задание по умолчанию.
i5_time_fmt
DB2_I5_FMT_ISO
— Используется формат времени
Международной организации по стандартизации ISO (hh.mm.ss). Это
значение по умолчанию.
DB2_I5_FMT_USA
— Используется формат времени США
(hh:mmxx, где xx — обозначение AM или PM).
DB2_I5_FMT_EUR
— Используется европейский формат
времени (hh.mm.ss).
DB2_I5_FMT_JIS
— Используется японский промышленный
стандартный формат времени (hh:mm:ss).
DB2_I5_FMT_HMS
— Используется формат hh:mm:ss.
i5_time_sep
DB2_I5_SEP_COLON
— В качестве разделителя
времени используется двоеточие ( : ). Это значение по умолчанию.
DB2_I5_SEP_PERIOD
— В качестве разделителя
времени используется точка ( . ).
DB2_I5_SEP_COMMA
— В качестве разделителя
времени используется запятая ( , ).
DB2_I5_SEP_BLANK
— В качестве разделителя времени
используется пробел.
DB2_I5_SEP_JOB
— Используется задание по умолчанию.
i5_decimal_sep
DB2_I5_SEP_PERIOD
— В качестве десятичного
разделителя используется точка ( . ). Это значение по умолчанию.
DB2_I5_SEP_COMMA
— В качестве десятичного
разделителя используется запятая ( , ).
DB2_I5_SEP_JOB
— Используется задание по умолчанию.
Данная новая опция ОС i5/OS доступна в модуле ibm_db2 версии 1.8.0 и новее.
i5_libl
Символьное значение, которое указывает список библиотек, который будет использоваться для разрешения неквалифицированных ссылок на файлы. Укажите элементы списка библиотек через пробелы: 'i5_libl'=>"MYLIB YOURLIB ANYLIB".
Замечание:
Параметр
i5_libl
вызывает qsys2/qcmdexc('cmd',cmdlen), который доступен только в ОС i5/OS V5R4 и новее.
Функция возвращает ресурс дескриптора подключения, если попытка подключения успешна.
Функция db2_connect() возвращает false
, елси возникла ошибка подключения.
Пример #1 Пример создания каталогизированного соединения
Каталогизированные соединения требуют, предварительной каталогизации базы данных через Command Line Processor (CLP) или Configuration Assistant базы данных DB2.
<?php
$database = 'SAMPLE';
$user = 'db2inst1';
$password = 'ibmdb2';
$conn = db2_connect($database, $user, $password);
if ($conn) {
echo "Соединение установлено.";
db2_close($conn);
} else {
echo "Не удалось установить соединение.";
}
?>
Результат выполнения приведённого примера:
Соединение установлено.
Пример #2 Пример создания некаталогизированного соединения
Некаталогизированное соединение разрешает динамически подключаться к базе данных.
<?php
$database = 'SAMPLE';
$user = 'db2inst1';
$password = 'ibmdb2';
$hostname = 'localhost';
$port = 50000;
$conn_string = "DRIVER={IBM DB2 ODBC DRIVER};DATABASE=$database;" .
"HOSTNAME=$hostname;PORT=$port;PROTOCOL=TCPIP;UID=$user;PWD=$password;"
;
$conn = db2_connect($conn_string, '', '');
if ($conn) {
echo "Соединение установлено.";
db2_close($conn);
} else {
echo "Не удалось установить соединение.";
}
?>
Результат выполнения приведённого примера:
Соединение установлено.
Пример #3 Пример создания соединения с отключённой автофиксацией по умолчанию
Передача массива параметров в функцию db2_connect() разрешает изменять поведение дескриптора соединения по умолчанию.
<?php
$database = 'SAMPLE';
$user = 'db2inst1';
$password = 'ibmdb2';
$options = array('autocommit' => DB2_AUTOCOMMIT_OFF);
$conn = db2_connect($database, $user, $password, $options);
if ($conn) {
echo "Соединение установлено.\n";
if (db2_autocommit($conn)) {
echo "Автофиксация включена.\n";
} else {
echo "Автофиксация выключена.\n";
}
db2_close($conn);
} else {
echo "Не удалось установить соединение.";
}
?>
Результат выполнения приведённого примера:
Соединение установлено. Автофиксация выключена.
Пример #4 Лучшая производительность ОС i5/OS
Чтобы добиться максимальной производительности PHP-приложения, которое работает с модулем ibm_db2 1.5.1 операционной системы i5/OS, указывают хост по умолчанию, идентификатор пользователя и пароль для функции db2_connect().
<?php
$library = "ADC";
$i5 = db2_connect("", "", "", array("i5_lib" => "qsys2"));
$result = db2_exec(
$i5,
"SELECT * FROM systables WHERE table_schema = '$library'"
);
while ($row = db2_fetch_both($result)) {
echo $row['TABLE_NAME'] . "<br>";
}
db2_close($i5);
?>
Результат выполнения приведённого примера:
ANIMALS NAMES PICTURES
Пример #5 Пример работы с доверенным контекстом
Пример показывает, как включить доверенный контекст, переключить пользователей и получить текущий идентификатор пользователя.
<?php
$database = "SAMPLE";
$hostname = "localhost";
$port = 50000;
$authID = "db2inst1";
$auth_pass = "ibmdb2";
$tc_user = "tcuser";
$tc_pass = "tcpassword";
$dsn = "DATABASE=$database;HOSTNAME=$hostname;PORT=$port;"
. "PROTOCOL=TCPIP;UID=$authID;PWD=$auth_pass;";
$options = array("trustedcontext" => DB2_TRUSTED_CONTEXT_ENABLE);
$tc_conn = db2_connect($dsn, "", "", $options);
if ($tc_conn) {
echo "Явное доверенное соединение установлено.\n";
if (db2_get_option($tc_conn, "trustedcontext")) {
$userBefore = db2_get_option($tc_conn, "trusted_user");
// Выполнение работы в качестве пользователя с идентификатором 1
// Переключение на доверенного пользователя
$parameters = array(
"trusted_user" => $tc_user,
"trusted_password" => $tcuser_pass
);
$res = db2_set_option($tc_conn, $parameters, 1);
$userAfter = db2_get_option($tc_conn, "trusted_user");
// Продолжение выполнения работы в качестве доверенного пользователя
if ($userBefore != $userAfter) {
echo "Пользователь был переключён." . "\n";
}
}
db2_close($tc_conn);
} else {
echo "Не удалось установить явное доверенное соединение.\n";
}
?>
Результат выполнения приведённого примера:
Явное доверенное соединение установлено. Пользователь был переключён.