oci_pconnect
(PHP 5, PHP 7, PHP 8, PECL OCI8 >= 1.1.0)
oci_pconnect — 使用一個持久連線連到 Oracle 數據庫
說明
string
$username
,string
$password
,string
$db
= ?,string
$charset
= ?,int
$session_mode
= ?): resource
oci_pconnect() 建立一個到 Oracle 伺服器的持久連線並登錄。持久連線會被緩衝並在請求之間重複使用,可以降低每個頁面載入的消耗。一個典型的 PHP 應用程式對於每個 Apache 子程序(或者 PHP FastCGI/CGI 程序)會有一個打開的持久連線到 Oracle 伺服器。更多資訊見數據庫持久連線一節。
注意: 自 OCI8 擴充套件庫版本 1.1 起,持久 Oracle 連線的生命週期和最大數目可以通過設定以下配置選項來調整:oci8.persistent_timeout,oci8.ping_interval 和 oci8.max_persistent。
可選的第三個參數可以是本地 Oracle 實例的名字或者是在
tnsnames.ora
的條目中的名字。如果沒有指定第三個參數, PHP 使用環境變數
ORACLE_SID
和 TWO_TASK
來分別確定本地 Oracle 實例的名字和
tnsnames.ora 的位置。
session_mode
參數自版本 1.1
起可用並接受如下值:OCI_DEFAULT
,OCI_SYSOPER
和 OCI_SYSDBA
。如果指定了
OCI_SYSOPER
或 OCI_SYSDBA
其中之一,oci_new_connect()
將嘗試使用外部認證資訊建立特權連線。特權連線預設被禁止。要啟用,需要將
oci8.privileged_connect
設為 On。
使用 Oracle 客戶端庫來確定字符集。字符集不需要與數據庫的字符集相匹配。如果不匹配,Oracle 會盡可能地將數據從數據庫字符集進行轉換。因為依賴於字符集,可能不能給出可用的結果。轉換也增加一些時間開銷。
如果不指定,Oracle 客戶端用 NLS_LANG
環境變數來決定字符集。
傳遞此參數可減少連線時間。
oci_pconnect() 返回連線識別符號,出錯則返回 false
。
注意:
在 PHP 5.0.0 之前的版本必須使用 ociplogon() 替代本函式。該函式名仍然可用,為向下相容作為 oci_pconnect() 的別名。不過其已被廢棄,不推薦使用。
參數
-
username
-
The Oracle user name.
-
password
-
The password for
username
. -
connection_string
-
包含要連線的
Oracle 實例
。可以是 » Easy Connect 串,或是 tnsnames.ora 檔案中的連線名,或是本地 Oracle 實例名。如果不指定或者為
null
,PHP 使用環境變數來確定連線的Oracle 實例
,諸如TWO_TASK
(Linux 下)或LOCAL
(Windows 下)與ORACLE_SID
等。要使用 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 加入類更多選項,例如 timeout 和 keep-alive 設定。 請參考 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 守護程序可讀取此檔案。 -
character_set
-
使用 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 系統。
返回值
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.