php7连接oracle数据库,使用一个持久连接连到 Oracle 数据库 - PHP 7 中文文档
(PHP 5, PHP 7, PECL OCI8 >= 1.1.0)
oci_pconnect – 使用一個持久連接連到 Oracle 數據庫
說明
oci_pconnect
( string $username
, string $password
[, string $db
[, string $charset
[, int $session_mode
]]] ) : resource
oci_pconnect() 創建一個到 Oracle
服務器的持久連接并登錄。持久連接會被緩沖并在請求之間重復使用,可以降低每個頁面加載的消耗。一個典型的
PHP 應用程序對于每個 Apache 子進程(或者 PHP FastCGI/CGI
進程)會有一個打開的持久連接到 Oracle 服務器。更多信息見[數據庫持久連接](php7/features.persistent-connections)一節。
Note:
自 OCI8 擴展庫版本 1.1 起,持久 Oracle
連接的生命周期和最大數目可以通過設定以下配置選項來調整:[oci8.persistent_timeout](php7/oci8.configuration),[oci8.ping_interval](php7/oci8.configuration)
和 [oci8.max_persistent](php7/oci8.configuration)。
可選的第三個參數可以是本地 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()](php7/function.oci-new-connect)
將嘗試使用外部認證信息建立特權連接。特權連接默認被禁止。要啟用,需要將
[oci8.privileged_connect](php7/oci8.configuration)
設為 On。
使用 Oracle
客戶端庫來確定字符集。字符集不需要與數據庫的字符集相匹配。如果不匹配,Oracle
會盡可能地將數據從數據庫字符集進行轉換。因為依賴于字符集,可能不能給出可用的結果。轉換也增加一些時間開銷。
如果不指定,Oracle 客戶端用 NLS_LANG 環境變量來決定字符集。
傳遞此參數可減少連接時間。
oci_pconnect() 返回連接標識符,出錯則返回 FALSE。
Note:
在 PHP 5.0.0 之前的版本必須使用 [ociplogon()](php7/function.ociplogon)
替代本函數。該函數名仍然可用,為向下兼容作為
oci_pconnect() 的別名。不過其已被廢棄,不推薦使用。
參見 [oci_connect()](php7/function.oci-connect) 和
[oci_new_connect()](php7/function.oci-new-connect)。
參數
username
The Oracle user name.
password
The password for username.
connection_string
包含要連接的
Oracle 實例。可以是 ? Easy Connect 串,或是
tnsnames.ora 文件中的連接名,或是本地 Oracle 實例名。
如果不指定,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 實用程序 lsnrctl status 找到。
tnsnames.ora 文件可在 Oracle Net 查找路徑中,此路徑包括 $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](php7/oci8.configuration)
設為 On 來啟用。
PHP 5.3(PECL OCI8 1.3.4)引進了
OCI_CRED_EXT 模式值。使用外部或操作系統認證必需在 Oracle
數據庫中進行配置。OCI_CRED_EXT
標志只可用于用戶為 "/",密碼為空的情況。[oci8.privileged_connect](php7/oci8.configuration)
可為 On 或 Off。
OCI_CRED_EXT 可與
OCI_SYSOPER 或
OCI_SYSDBA 模式組合使用。
OCI_CRED_EXT 由于安全的原因不支持 Windows 系統。
返回值
Returns a connection identifier or FALSE on error.
注釋
Note:
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](php7/oci8.configuration),
[oci8.ping_interval](php7/oci8.configuration) and
[oci8.max_persistent](php7/oci8.configuration).
Note:
In PHP versions before 5.0.0 you must
use [ociplogon()](php7/function.ociplogon) instead.
在當前版本中,舊的函數名還可以被使用,但已經被廢棄并不建議使用。
參見
[oci_connect()](php7/function.oci-connect) – 建立一個到 Oracle 服務器的連接
[oci_new_connect()](php7/function.oci-new-connect) – 建定一個到 Oracle 服務器的新連接
總結
以上是生活随笔為你收集整理的php7连接oracle数据库,使用一个持久连接连到 Oracle 数据库 - PHP 7 中文文档的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 苹果承认 watchOS 10.1 存在
- 下一篇: 英特尔锐炫显卡驱动迎更新 游戏性能暴涨