久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP使用PDO訪問oracle數據庫的步驟詳解

POD擴展是在PHP5中加入,該擴展提供PHP內置類 PDO來對數據庫進行訪問,不同數據庫使用相同的方法名,解決數據庫連接不統一的問題。下面這篇文章主要給大家介紹了關于PHP使用PDO訪問

前言

PDO 從一開始就吸取了現有數據庫擴展成功和失敗的經驗教訓。因為 PDO 的代碼是全新的,所以我們有機會重新開始設計性能,以利用 PHP 5 的最新特性。

PDO 旨在將常見的數據庫功能作為基礎提供,同時提供對于 RDBMS 獨特功能的方便訪問。

雖然LAMP中PHP和Mysql是標準配對,但是公司的項目是Mysql和Oracle分別作為運行庫和詳單庫的,所以PHP連接oracle數據庫也是必須要實現的。本篇文章就介紹下如果通過PDO連接到oracle數據庫,下面話不多說了,來一起看看詳細的介紹吧。

開發(fā)環(huán)境

同樣先說明下我使用到的環(huán)境:

  • RedHat(CentOS)6.7
  • PHP5.6
  • Oracle11g

php5.6的搭建可以參照這里;

Oracle在linux環(huán)境下的安裝可以參考這里

當然,你也可以不安裝整個oracle,而只安裝instant client來實現;如果是instant client的oracle連接步驟參見本篇博文最后的致謝部分。

在開始下面的步驟前,請務必確保以上的3個環(huán)境都正確配置可用。

安裝PDO_OCI

如果你是安裝的php5.6.31版本,似乎pdo_oci模塊已經自帶了;但是穩(wěn)妥起見,我們重新安裝一遍。

下載并解壓縮

$ wget https://pecl.php.net/get/PDO_OCI-1.0.tgz
$ tar -xvf PDO_OCI-1.0.tgz
$ cd PDO_OCI-1.0

修改配置文件

更新目錄中的config.m4文件,使其適配Oracle11g

# 在第10行左右找到與下面類似的代碼,添加這兩行:
elif test -f $PDO_OCI_DIR/lib/libclntsh.$SHLIB_SUFFIX_NAME.11.2; then
 PDO_OCI_VERSION=11.2

# 在第101行左右添加這幾行:
11.2)
 PHP_ADD_LIBRARY(clntsh, 1, PDO_OCI_SHARED_LIBADD)
 ;;

編譯

在當前目錄下執(zhí)行

$ phpize

phpize類似于gcc命令,主要是用來生成php的外掛模塊。phpize是依賴于php-deval模塊的,如果命令無法執(zhí)行,請自行利用yum安裝php-deval;

你可以通過下面的命令檢查下是否已經安裝:

$ rpm -qa | grep php

查看是否有php56w-deval-5.6.xxx,如果沒有,請yum install php56w-deval來安裝。

安裝

phpize命令執(zhí)行之后,會在目錄下生成很多文件,其中包括configure等我們常見的linux下通過源碼安裝應用的標準文件,依次執(zhí)行下面的命令:

$ ./configure
$ make && make install

這里一般會遇到一個問題,在make的時候會提示在pdo_oci.c文件中:

pdo_oci.c:34: error: expected ‘=', ‘,', ‘;', ‘asm' or ‘attribute' before ‘pdo_oci_functions'

解決辦法是修改pdo_oci.c文件的第34行,把function_entry修改成zend_function_entry,保存后重新make就可以了。

創(chuàng)建ini文件

成功之后,會提示已經在/usr/lib64/php/modules目錄下生成了pdo_oci.so模塊,我們要做的就是告訴php,我們要引用這個模塊。

在/etc/php.d目錄下新建一個ini文件:pdo_oci.ini,內容:

extension=pdo_oci.so

到這里,pdo_oci模塊就安裝完成了,我們可以通過php -m | grep oci來查看。

安裝OCI8

接下來就是安裝oci8模塊。

下載并解壓縮

依次在命令行中執(zhí)行下面的命令:

$ wget https://pecl.php.net/get/oci8-2.0.8.tgz
$ tar -xvf oci8-2.0.8.tgz
$ cd oci8-2.0.8

編譯和安裝

步驟和上面pdo_oci是類似的:

$ phpize
$ ./configure --with-oci8=shared
$ make && make install

創(chuàng)建ini文件

同樣的,我們在/etc/php.d目錄下創(chuàng)建oci8.ini,內容:

extension=oci8.so

重啟Apache

別忘記重啟一下apache服務器來重新加載php的模塊:

$ service httpd restart

我們可以通過在網站目錄下創(chuàng)建一個test.php文件,文件中的內容是:

<?php
phpinfo();

然后我們到頁面中去查看下打印出來的phpinfo信息,查看其中的pdo, pdo_oci和oci8模塊的相關信息。

總結

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業(yè)用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結合實例形式分析了php實現針對有序表插值查找的相關操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實現服務端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實現APP微信支付的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實現的多維數組排序算法,結合實例形式對比分析了php針對多維數組及帶有鍵名的多維數組進行排序相關操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要為大家詳細介紹了php結合ajaxuploadfile實現無刷新文件上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細介紹了PHP開發(fā)接口使用RSA進行加密解密方法,對此有興趣的朋友可以學習下。
主站蜘蛛池模板: 亚洲精品美女视频 | 黄色毛片免费 | 欧美在线一区二区三区 | 欧美日韩国产高清 | 毛片一区二区三区 | 奇米av | 男人阁久久 | 国产婷婷精品 | 一区亚洲| 久久噜| 奇米久久 | 欧美精品网 | 妞干网av| 久久久久免费精品国产 | 精品一区国产 | 91性高湖久久久久久久久_久久99 | 国产精品99精品久久免费 | 97国产精品视频人人做人人爱 | 在线看日韩| 亚洲成网 | 久久久精品视 | 色综合99| 六月成人网 | 欧美成人一级视频 | 狠狠色综合欧美激情 | 日本高清不卡视频 | 国产一区二区三区精品久久久 | 精品无码久久久久久久动漫 | 又爽又黄axxx片免费观看 | 高清久久久 | 久久久久亚洲av毛片大全 | 国产亚洲一区二区精品 | 国产成人精品在线播放 | 久久免费精品 | 国产视频一区二区三区四区五区 | 色综合久久88色综合天天 | 一区二区三区国产 | 国产一区二区三区欧美 | 久久最新| 久久免费视频1 | 伊人亚洲 |