(PHP 5, PHP 7, PHP 8, PECL OCI8 >= 1.1.0)
oci_pconnect — 使用一個(gè)持久連接連到 Oracle 數(shù)據(jù)庫(kù)
$username
,$password
,$db
= ?,$charset
= ?,$session_mode
= ?oci_pconnect() 創(chuàng)建一個(gè)到 Oracle 服務(wù)器的持久連接并登錄。持久連接會(huì)被緩沖并在請(qǐng)求之間重復(fù)使用,可以降低每個(gè)頁(yè)面加載的消耗。一個(gè)典型的 PHP 應(yīng)用程序?qū)τ诿總€(gè) Apache 子進(jìn)程(或者 PHP FastCGI/CGI 進(jìn)程)會(huì)有一個(gè)打開(kāi)的持久連接到 Oracle 服務(wù)器。更多信息見(jiàn)數(shù)據(jù)庫(kù)持久連接一節(jié)。
注意: 自 OCI8 擴(kuò)展庫(kù)版本 1.1 起,持久 Oracle 連接的生命周期和最大數(shù)目可以通過(guò)設(shè)定以下配置選項(xiàng)來(lái)調(diào)整:oci8.persistent_timeout,oci8.ping_interval 和 oci8.max_persistent。
可選的第三個(gè)參數(shù)可以是本地 Oracle 實(shí)例的名字或者是在
tnsnames.ora
的條目中的名字。如果沒(méi)有指定第三個(gè)參數(shù), PHP 使用環(huán)境變量
ORACLE_SID
和 TWO_TASK
來(lái)分別確定本地 Oracle 實(shí)例的名字和
tnsnames.ora 的位置。
session_mode
參數(shù)自版本 1.1
起可用并接受如下值:OCI_DEFAULT
,OCI_SYSOPER
和 OCI_SYSDBA
。如果指定了
OCI_SYSOPER
或 OCI_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í)間開(kāi)銷。
如果不指定,Oracle 客戶端用 NLS_LANG
環(huán)境變量來(lái)決定字符集。
傳遞此參數(shù)可減少連接時(shí)間。
oci_pconnect() 返回連接標(biāo)識(shí)符,出錯(cuò)則返回 false
。
注意:
在 PHP 5.0.0 之前的版本必須使用 ociplogon() 替代本函數(shù)。該函數(shù)名仍然可用,為向下兼容作為 oci_pconnect() 的別名。不過(guò)其已被廢棄,不推薦使用。
參見(jiàn) oci_connect() 和 oci_new_connect()。
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
以便通過(guò) $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)橐蕾囉谧址赡懿荒芙o出可用的結(jié)果。轉(zhuǎn)換也增加一些時(shí)間開(kāi)銷。
如果不指定,Oracle 客戶端用 NLS_LANG
環(huán)境變量來(lái)決定字符集。
傳遞此參數(shù)可減少連接時(shí)間。
session_mode
此參數(shù)在 PHP 5(PECL OCI8
1.1)版本開(kāi)始可用,并收受下列值:OCI_DEFAULT
,OCI_SYSOPER
和 OCI_SYSDBA
。如為
OCI_SYSOPER
或 OCI_SYSDBA
其中之一,此函數(shù)將會(huì)使用外部的證書(shū)建立有特權(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
可為 On
或 Off
。
OCI_CRED_EXT
可與
OCI_SYSOPER
或
OCI_SYSDBA
模式組合使用。
OCI_CRED_EXT
由于安全的原因不支持 Windows 系統(tǒng)。
Returns a connection identifier or false
on error.
注意: Starting with PHP 5.1.2 and PECL oci8 1.1, the lifetime and maximum number of persistent Oracle connections can be tuned by setting the following configuration values: oci8.persistent_timeout, oci8.ping_interval and oci8.max_persistent.
注意:
In PHP versions before 5.0.0 you must use ociplogon() instead.