(PHP 5, PHP 7, PHP 8, PECL OCI8 >= 1.1.0)
oci_new_connect — 使用唯一连接连接到 Oracle 服务器
$username
,$password
,$connection_string
= null
,$encoding
= "",$session_mode
= OCI_DEFAULT
建立到 Oracle 服务器的新连接并登录。
与 oci_connect() 和 oci_pconnect() 不同,oci_new_connect() 不缓存连接,并且始终返回一个全新的、新打开的连接句柄。 如果您的应用程序需要在两组查询之间进行事务隔离,这很有用。
username
Oracle 用户名。
password
username
的密码。
connection_string
包含要连接到的 Oracle 实例
。 它可以是 » Easy Connect 字符串、tnsnames.ora 文件中的连接名称或本地 Oracle 实例的名称。
如果未指定或为 null
,则 PHP 使用环境变量(如 TWO_TASK
(在 Linux 上)或 LOCAL
(在 Windows 上)以及 ORACLE_SID
)来确定要连接到的 Oracle 实例
。
要使用 Easy Connect 命名方法,PHP 必须与 Oracle 10g 或更高版本的客户端库链接。 Oracle 10g 的 Easy Connect 字符串形式为:[//]host_name[:port][/service_name]。 从 Oracle 11g 开始,语法为:[//]host_name[:port][/service_name][:server_type][/instance_name]。 Oracle 19c 引入了更多选项,包括超时和保持活动设置。 请参阅 Oracle 文档。 服务名称可以通过在数据库服务器机器上运行 Oracle 实用程序 lsnrctl status
来找到。
tnsnames.ora 文件可以在 Oracle Net 搜索路径中,其中包括 /your/path/to/instantclient/network/admin、$ORACLE_HOME/network/admin 和 /etc。 或者设置 TNS_ADMIN
,以便读取 $TNS_ADMIN/tnsnames.ora。 确保 Web 守护程序对该文件具有读取权限。
encoding
确定 Oracle 客户端库使用的字符集。 字符集不必与数据库使用的字符集匹配。 如果不匹配,Oracle 将尽力将数据转换为数据库字符集并从数据库字符集中转换。 具体取决于字符集,这可能无法提供可用的结果。 转换还会增加一些时间开销。
如果未指定,Oracle 客户端库从 NLS_LANG
环境变量中确定字符集。
传递此参数可以减少连接所需的时间。
session_mode
此参数从 PHP 5(PECL OCI8 1.1)版本开始可用,并接受以下值:OCI_DEFAULT
、OCI_SYSOPER
和 OCI_SYSDBA
。 如果指定了 OCI_SYSOPER
或 OCI_SYSDBA
,则此函数将尝试使用外部凭据建立特权连接。 默认情况下禁用特权连接。 要启用它们,您需要将 oci8.privileged_connect 设置为 On
。
PHP 5.3(PECL OCI8 1.3.4)引入了 OCI_CRED_EXT
模式值。 这告诉 Oracle 使用外部或操作系统身份验证,这必须在数据库中进行配置。 OCI_CRED_EXT
标志只能与用户名“/”和空密码一起使用。 oci8.privileged_connect 可以是 On
或 Off
。
OCI_CRED_EXT
可以与 OCI_SYSOPER
或 OCI_SYSDBA
模式组合。
出于安全原因,OCI_CRED_EXT
在 Windows 上不受支持。
返回连接标识符或在错误时返回 false
。
版本 | 描述 |
---|---|
8.0.0, PECL OCI8 3.0.0 |
connection_string 现在可以为空。 |
以下演示了如何分离连接。
示例 #1 oci_new_connect() 例子
<?php
// 创建表 mytab (mycol number);
function query($name, $c)
{
echo "查询 $name\n";
$s = oci_parse($c, "select * from mytab");
oci_execute($s, OCI_NO_AUTO_COMMIT);
$row = oci_fetch_array($s, OCI_ASSOC);
if (!$row) {
echo "没有行\n";
} else {
do {
foreach ($row as $item)
echo $item . " ";
echo "\n";
} while (($row = oci_fetch_array($s, OCI_ASSOC)) != false);
}
}
$c1 = oci_connect("hr", "welcome", "localhost/orcl");
$c2 = oci_new_connect("hr", "welcome", "localhost/orcl");
$s = oci_parse($c1, "insert into mytab values(1234)");
oci_execute($s, OCI_NO_AUTO_COMMIT);
query("基本连接", $c1);
query("新连接", $c2);
oci_commit($c1);
query("提交后的新连接", $c2);
// 输出为:
// 查询 基本连接
// 1234
// 查询 新连接
// 没有行
// 查询 提交后的新连接
// 1234
?>
有关参数用法的更多示例,请参见 oci_connect()。