(PECL ibm_db2 >= 1.0.0)
db2_autocommit — 返回或设置数据库连接的 AUTOCOMMIT 状态
connection
一个有效的数据库连接资源变量,由 db2_connect() 或 db2_pconnect() 返回。
value
以下常量之一
DB2_AUTOCOMMIT_OFF
关闭 AUTOCOMMIT。
DB2_AUTOCOMMIT_ON
打开 AUTOCOMMIT。
当 db2_autocommit() 只接收 connection
参数时,它会以整数形式返回请求连接的 AUTOCOMMIT 的当前状态。值为 DB2_AUTOCOMMIT_OFF
表示 AUTOCOMMIT 已关闭,而值为 DB2_AUTOCOMMIT_ON
表示 AUTOCOMMIT 已打开。
当 db2_autocommit() 同时接收 connection
参数和 autocommit
参数时,它会尝试将请求连接的 AUTOCOMMIT 状态设置为相应的状态。成功返回 true
,失败返回 false
。
范例 #1 获取连接的 AUTOCOMMIT 值
在下面的例子中,使用 db2_autocommit() 函数测试一个已创建且 AUTOCOMMIT 关闭的连接。
<?php
$options = array('autocommit' => DB2_AUTOCOMMIT_OFF);
$conn = db2_connect($database, $user, $password, $options);
$ac = db2_autocommit($conn);
if ($ac == DB2_AUTOCOMMIT_OFF) {
print "$ac -- AUTOCOMMIT 已关闭.";
} else {
print "$ac -- AUTOCOMMIT 已打开.";
}
?>
上述例子将输出
0 -- AUTOCOMMIT is off.
范例 #2 设置连接的 AUTOCOMMIT 值
在下面的例子中,一个最初创建时 AUTOCOMMIT 关闭的连接,其行为被更改为打开 AUTOCOMMIT。
<?php
$options = array('autocommit' => DB2_AUTOCOMMIT_OFF);
$conn = db2_connect($database, $user, $password, $options);
// 打开 AUTOCOMMIT
$rc = db2_autocommit($conn, DB2_AUTOCOMMIT_ON);
if ($rc) {
print "打开 AUTOCOMMIT 成功。\n";
}
// 检查 AUTOCOMMIT 状态
$ac = db2_autocommit($conn);
if ($ac == DB2_AUTOCOMMIT_OFF) {
print "$ac -- AUTOCOMMIT 已关闭.";
} else {
print "$ac -- AUTOCOMMIT 已打开.";
}
?>
上述例子将输出
Turning AUTOCOMMIT on succeeded. 1 -- AUTOCOMMIT is on.