oci_new_connect

(PHP 5, PHP 7, PHP 8, PECL OCI8 >= 1.1.0)

oci_new_connect建定一個(gè)到 Oracle 服務(wù)器的新連接

說(shuō)明

oci_new_connect(
    string $username,
    string $password,
    string $db = ?,
    string $charset = ?,
    int $session_mode = ?
): resource

oci_new_connect() 創(chuàng)建一個(gè)到 Oracle 服務(wù)器的新連接并登錄。與 oci_connect()oci_pconnect() 不同,oci_new_connect() 不會(huì)緩沖連接,總是會(huì)返回一個(gè)全新的剛打開的連接句柄。這在應(yīng)用程序需要在兩組查詢之間實(shí)現(xiàn)事務(wù)隔離很有用。

可選的第三個(gè)參數(shù)可以是本地 Oracle 實(shí)例的名字或者是在 tnsnames.ora 的條目中的名字。如果沒有指定第三個(gè)參數(shù), PHP 使用環(huán)境變量 ORACLE_SIDTWO_TASK 來(lái)分別確定本地 Oracle 實(shí)例的名字和 tnsnames.ora 的位置。

session_mode 參數(shù)自版本 1.1 起可用并接受如下值:OCI_DEFAULT,OCI_SYSOPEROCI_SYSDBA。如果指定了 OCI_SYSOPEROCI_SYSDBA 其中之一,oci_new_connect() 將嘗試使用外部認(rèn)證信息建立特權(quán)連接。特權(quán)連接默認(rèn)被禁止。要啟用,需要將 oci8.privileged_connect 設(shè)為 On。

使用 Oracle 客戶端庫(kù)來(lái)確定字符集。字符集不需要與數(shù)據(jù)庫(kù)的字符集相匹配。如果不匹配,Oracle 會(huì)盡可能地將數(shù)據(jù)從數(shù)據(jù)庫(kù)字符集進(jìn)行轉(zhuǎn)換。因?yàn)橐蕾囉谧址?,可能不能給出可用的結(jié)果。轉(zhuǎn)換也增加一些時(shí)間開銷。

如果不指定,Oracle 客戶端用 NLS_LANG 環(huán)境變量來(lái)決定字符集。

傳遞此參數(shù)可減少連接時(shí)間。

下面例子演示了怎樣隔離連接。

示例 #1 oci_new_connect() 例子

<?php
echo "<html><pre>";
$db "";

$c1 oci_connect("scott""tiger"$db);
$c2 oci_new_connect("scott""tiger"$db);

function 
create_table($conn)
{
  
$stmt oci_parse($conn"create table scott.hallo (test
varchar2(64))"
);
  
oci_execute($stmt);
  echo 
$conn " created table\n\n";
}

function 
drop_table($conn)
{
  
$stmt oci_parse($conn"drop table scott.hallo");
  
oci_execute($stmt);
  echo 
$conn " dropped table\n\n";
}

function 
insert_data($conn)
{
  
$stmt oci_parse($conn"insert into scott.hallo
            values('
$conn' || ' ' || to_char(sysdate,'DD-MON-YY HH24:MI:SS'))");
  
oci_execute($stmtOCI_DEFAULT);
  echo 
$conn " inserted hallo\n\n";
}

function 
delete_data($conn)
{
  
$stmt oci_parse($conn"delete from scott.hallo");
  
oci_execute($stmtOCI_DEFAULT);
  echo 
$conn " deleted hallo\n\n";
}

function 
commit($conn)
{
  
oci_commit($conn);
  echo 
$conn " committed\n\n";
}

function 
rollback($conn)
{
  
oci_rollback($conn);
  echo 
$conn " rollback\n\n";
}

function 
select_data($conn)
{
  
$stmt oci_parse($conn"select * from scott.hallo");
  
oci_execute($stmtOCI_DEFAULT);
  echo 
$conn "----selecting\n\n";
  while (
oci_fetch($stmt)) {
    echo 
$conn " <" oci_result($stmt"TEST") . ">\n\n";
  }
  echo 
$conn "----done\n\n";
}

create_table($c1);
insert_data($c1);

select_data($c1);
select_data($c2);

rollback($c1);

select_data($c1);
select_data($c2);

insert_data($c2);
commit($c2);

select_data($c1);

delete_data($c1);
select_data($c1);
select_data($c2);
commit($c1);

select_data($c1);
select_data($c2);

drop_table($c1);
echo 
"</pre></html>";
?>

oci_new_connect() 在出錯(cuò)時(shí)返回 false。

注意:

在 PHP 5.0.0 之前的版本必須使用 ocinlogon() 替代本函數(shù)。該函數(shù)名仍然可用,為向下兼容作為 oci_new_connect() 的別名。不過其已被廢棄,不推薦使用。

參見 oci_connect()oci_pconnect()

參數(shù)

username

The Oracle user name.

password

The password for username.

connection_string

包含要連接的 Oracle 實(shí)例??梢允?? Easy Connect 串,或是 tnsnames.ora 文件中的連接名,或是本地 Oracle 實(shí)例名。

如果不指定或者為 null,PHP 使用環(huán)境變量來(lái)確定連接的 Oracle 實(shí)例,諸如 TWO_TASK(Linux 下)或 LOCAL(Windows 下)與 ORACLE_SID 等。

要使用 Easy Connect 命名方法,PHP 必須與 Oracle 10g 或更高版本的客戶端庫(kù)進(jìn)行鏈接。Oracle 10g 的 Easy Connect 串格式:[//]host_name[:port][/service_name]。Oracle 11g 則為:[//]host_name[:port][/service_name][:server_type][/instance_name]。 在 Oracle 19c 加入類更多選項(xiàng),例如 timeout 和 keep-alive 設(shè)置。 請(qǐng)參考 Oracle 文檔。 服務(wù)名可在數(shù)據(jù)庫(kù)服務(wù)器機(jī)器上運(yùn)行 Oracle 實(shí)用程序 lsnrctl status 找到。

tnsnames.ora 文件可在 Oracle Net 查找路徑中,此路徑包括 /your/path/to/instantclient/network/admin、$ORACLE_HOME/network/admin 、/etc。 另一種方法是設(shè)置 TNS_ADMIN 以便通過 $TNS_ADMIN/tnsnames.ora 來(lái)讀取。表確認(rèn) web 守護(hù)進(jìn)程可讀取此文件。

character_set

使用 Oracle 客戶端庫(kù)來(lái)確定字符集。字符集不需要與數(shù)據(jù)庫(kù)的字符集相匹配。如果不匹配,Oracle 會(huì)盡可能地將數(shù)據(jù)從數(shù)據(jù)庫(kù)字符集進(jìn)行轉(zhuǎn)換。因?yàn)橐蕾囉谧址?,可能不能給出可用的結(jié)果。轉(zhuǎn)換也增加一些時(shí)間開銷。

如果不指定,Oracle 客戶端用 NLS_LANG 環(huán)境變量來(lái)決定字符集。

傳遞此參數(shù)可減少連接時(shí)間。

session_mode

此參數(shù)在 PHP 5(PECL OCI8 1.1)版本開始可用,并收受下列值:OCI_DEFAULT,OCI_SYSOPEROCI_SYSDBA。如為 OCI_SYSOPEROCI_SYSDBA 其中之一,此函數(shù)將會(huì)使用外部的證書建立有特權(quán)的連接。有特權(quán)的連接默認(rèn)是禁用的。需要將 oci8.privileged_connect 設(shè)為 On 來(lái)啟用。

PHP 5.3(PECL OCI8 1.3.4)引進(jìn)了 OCI_CRED_EXT 模式值。使用外部或操作系統(tǒng)認(rèn)證必需在 Oracle 數(shù)據(jù)庫(kù)中進(jìn)行配置。OCI_CRED_EXT 標(biāo)志只可用于用戶為 "/",密碼為空的情況。oci8.privileged_connect 可為 OnOff。

OCI_CRED_EXT 可與 OCI_SYSOPEROCI_SYSDBA 模式組合使用。

OCI_CRED_EXT 由于安全的原因不支持 Windows 系統(tǒng)。

返回值

Returns a connection identifier or false on error.

范例

The following demonstrates how you can separate connections.

示例 #2 oci_new_connect() example

<?php
echo "<html><pre>";
$db "";

$c1 oci_connect("scott""tiger"$db);
$c2 oci_new_connect("scott""tiger"$db);

function 
create_table($conn)
{
  
$stmt oci_parse($conn"create table scott.hallo (test
varchar2(64))"
);
  
oci_execute($stmt);
  echo 
$conn " created table\n\n";
}

function 
drop_table($conn)
{
  
$stmt oci_parse($conn"drop table scott.hallo");
  
oci_execute($stmt);
  echo 
$conn " dropped table\n\n";
}

function 
insert_data($conn)
{
  
$stmt oci_parse($conn"insert into scott.hallo
            values('
$conn' || ' ' || to_char(sysdate,'DD-MON-YY HH24:MI:SS'))");
  
oci_execute($stmtOCI_DEFAULT);
  echo 
$conn " inserted hallo\n\n";
}

function 
delete_data($conn)
{
  
$stmt oci_parse($conn"delete from scott.hallo");
  
oci_execute($stmtOCI_DEFAULT);
  echo 
$conn " deleted hallo\n\n";
}

function 
commit($conn)
{
  
oci_commit($conn);
  echo 
$conn " committed\n\n";
}

function 
rollback($conn)
{
  
oci_rollback($conn);
  echo 
$conn " rollback\n\n";
}

function 
select_data($conn)
{
  
$stmt oci_parse($conn"select * from scott.hallo");
  
oci_execute($stmtOCI_DEFAULT);
  echo 
$conn "----selecting\n\n";
  while (
oci_fetch($stmt)) {
    echo 
$conn " <" oci_result($stmt"TEST") . ">\n\n";
  }
  echo 
$conn "----done\n\n";
}

create_table($c1);
insert_data($c1);

select_data($c1);
select_data($c2);

rollback($c1);

select_data($c1);
select_data($c2);

insert_data($c2);
commit($c2);

select_data($c1);

delete_data($c1);
select_data($c1);
select_data($c2);
commit($c1);

select_data($c1);
select_data($c2);

drop_table($c1);
echo 
"</pre></html>";
?>

注釋

注意:

In PHP versions before 5.0.0 you must use ocinlogon() instead.

參見

  • oci_connect() - 建立一個(gè)到 Oracle 服務(wù)器的連接
  • oci_pconnect() - 使用一個(gè)持久連接連到 Oracle 數(shù)據(jù)庫(kù)