您好,登錄后才能下訂單哦!
實現(xiàn)PHP程序訪問oracle DB
時間:2014.09.02
寫作者:劉群英(qunyingliu)
環(huán)境描述:apache版本,PHP版本,oracle DB版本,linux發(fā)行版本
RPM包安裝oracle-instantclient客戶端
源碼編譯安裝oci8擴(kuò)展
系統(tǒng)環(huán)境與php配置修改:ld.so.conf.d目錄配置文件與php.ini中擴(kuò)展字段信息修改
重啟apache使修改生效
測試鏈接代碼,確認(rèn)配置成功
環(huán)境描述:
本地系統(tǒng):centos linux 6.4 x64
apache 2.2.22:/usr/local/apache2
PHP 5.4 : /usr/local/php
oracle DB 11.2.0.4
RPM包安裝本地oracle client:
從[oracle Instant Client 官網(wǎng) 下載以下RPM包:
http://www.oracle.com/technetwork/cn/topics/linuxx86-64soft-092277.html
oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm
oracle-instantclient11.2-sqlplus-11.2.0.4.0-1.x86_64.rpm
使用以下命令進(jìn)行安裝:
rpm -ivh oracle-instantclient11.2-basic-11.2.0.4.0-1.x86_64.rpm
rpm -ivh oracle-instantclient11.2-devel-11.2.0.4.0-1.x86_64.rpm
rpm -ivh oracle-instantclient11.2-sqlplus-11.2.0.4.0-1.x86_64.rpm
源碼編譯安裝oci8擴(kuò)展下載:
wget http://pecl.php.net/get/oci8-1.4.10.tgz
解壓:tar -zxvf oci8-1.4.10.tgz
安裝:
cd oci8-1.4.10/usr/local/php/bin/phpize CFLAGS="-I/usr/lib/oracle/11.2.0.4.0/client64/" CXXFLAGS="-I/usr/lib/oracle/11.2.0.4.0/client64/"
./configure --with-php-config=/usr/local/php/bin/php-config --with-oci8=instantclient,/usr/lib/oracle/11.2.0.4.0/client64/lib/
make
make instal
lphp路徑和oracle client的路徑需根據(jù)實際情況進(jìn)行修改。
如果系統(tǒng)中存在pecl程序,可通過以下命令來安裝oci8擴(kuò)展:
pecl install oci8
系統(tǒng)環(huán)境與php配置修改修改系統(tǒng)配置:
echo "/usr/lib/oracle/11.2.0.4.0/client64//lib/"
>/etc/ld.so.conf.d/oracle_client.conf/sbin/ldconfig
修改php.ini配置文件:
extension_dir = "/usr/local/php5/lib/ext"
extension = "oci8.so"
oci8.privileged_connect = on
重啟apache使修改生效
/usr/local/apache2/bin/apachectl restart
測試鏈接代碼,確認(rèn)配置成功
<?php
$conn = oci_connect('qunyingliu', 'testqunyingliu', 'oracle.test.localhost/orcl');
//需要根據(jù)實際配置信息進(jìn)行修改
$stid = oci_parse($conn, 'select table_name from user_tables');
//數(shù)據(jù)庫操作語句可根據(jù)實際需求進(jìn)行修改
oci_execute($stid);
echo "<table>\n";
while (($row = oci_fetch_array($stid, OCI_ASSOC+OCI_RETURN_NULLS)) != false) {
echo "
\n";
foreach ($row as $item) {
echo "<td>".($item !== null ? htmlentities($item, ENT_QUOTES) : " ")."\n";
}
echo "\n";
}
echo "</table>\n";
?>
相關(guān)參考:
http://php.net/manual/zh/function.oci-connect.php
http://php.net/manual/zh/book.oci8.php
http://pecl.php.net/get/oci8-1.4.10.tgz
http://pecl.php.net/package-changelog.php?package=oci8
http://www.oracle.com/technetwork/cn/topics/linuxx86-64soft-092277.html
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。