(PHP 5 >= 5.3.2, PHP 7, PHP 8, PECL OCI8 >= 1.4.0)
oci_set_action — 设置操作名称
为 Oracle 跟踪设置操作名称。
当 PHP 到数据库的下一个“往返”发生时,操作名称将在数据库中注册,通常是在执行 SQL 语句时。
操作名称随后可以从数据库管理视图中查询,例如 V$SESSION
。它可用于跟踪和监控,例如使用 V$SQLAREA
和 DBMS_MONITOR.SERV_MOD_ACT_STAT_ENABLE
。
该值可以在持久连接中保留。
connection
由 oci_connect()、oci_pconnect() 或 oci_new_connect() 返回的 Oracle 连接标识符。
action
用户选择的字符串,长度不超过 32 个字节。
示例 #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);
?>
// While the script is running, the administrator can see the actions // being performed: sqlplus system/welcome SQL> select action from v$session;
注意: Oracle 版本要求
当 PHP 与 10g 及更高版本的 Oracle 数据库库链接时,此函数可用。
使用较旧版本的 OCI8 或 Oracle 数据库,可以使用 Oracle 的 DBMS_APPLICATION_INFO
包来设置客户端信息。这不如使用 oci_set_client_info() 效率高。
某些但并非所有 OCI8 函数都会导致往返。当启用结果缓存时,查询可能不会发生往返数据库。