(PHP 5.3.2, PECL OCI8 >= 1.4.0)
oci_set_action — Задает имя для действия
$connection
, string $action_name
)Присваивает имя действию для трассировки Oracle.
Присвоенное имя регистрируется в базе данных во время очередного запроса от PHP, например, когда запускается SQL выражение.
Имя действия может быть извлечено из административных представлений (view) базы данных, таких как V$SESSION. Его можно использовать для трассировки и мониторинга, например, с помощью V$SQLAREA и DBMS_MONITOR.SERV_MOD_ACT_STAT_ENABLE.
Значение можно устанавливать и через постоянные соединения.
connection
Идентификатор соединения Oracle, возвращаемый oci_connect(), oci_pconnect(), или oci_new_connect().
action_name
Задаваемая пользователем строка до 32 байт.
Возвращает TRUE
в случае успешного завершения или FALSE
в случае возникновения ошибки.
Пример #1 Установка действия
<?php
$c = oci_connect('hr', 'welcome', 'localhost/XE');
// Запись действия
oci_set_action($c, 'Friend Lookup');
// Код, осуществляющий запрос к БД, например выборка:
$s = oci_parse($c, 'select * from dual');
oci_execute($s);
oci_fetch_all($s, $res);
sleep(30);
?>
// Пока скрипт выполняется, администратор может наблюдать выполнение действий: sqlplus system/welcome SQL> select action from v$session;
Замечание: Требование к версии Oracle
Эта функция доступна, если PHP слинкован с библиотеками Oracle Database начиная с версии 10g и выше.
В старых версиях OCI8 или базы данных Oracle было возможно установить информацию о клиенте с помощью пакета DBMS_APPLICATION_INFO. Для этой цели более эффективно использование функции oci_set_client_info().
Некоторые, но не все OCI8-функции вызывают полное сканирование таблицы (roundtrip). Полное сканирование таблиц не происходит для тех запросов, в которых включено кэширование результатов в базе данных.