php連接Oracle數(shù)據(jù)庫(kù)

要想用php連接Oracle,需要:

1.安裝并配置Oracle instant Client
2.配置php的php_oci8_11g拓展

一苍柏、Window

(一)安裝Oracle instant Client

根據(jù)系統(tǒng)和PHP版本信息去Oracle官網(wǎng)下載相應(yīng)的Oracle instant Client版本
右鍵我的電腦,選中屬性-高級(jí)系統(tǒng)設(shè)置-高級(jí)-環(huán)境變量,在Path中加入Oracle instant Client所在的路徑

(二)配置php_oci8_11g拓展

根據(jù)phpinfo()的信息,前往oci8拓展下載相應(yīng)版本的dll玲昧,將下載了的dll放到php的ext目錄,并且在php.ini配置文件中加入extension=php_oci8_11g.dll篮绿,重啟php,可以通過(guò)命令行調(diào)用php -m查看模塊是否加載

(三)錯(cuò)誤

1.提示"%1 不是有效的 Win32 應(yīng)用程序"
Oracle instant Client版本有問(wèn)題吕漂,要根據(jù)PHP版本來(lái)確定Oracle instant Client版本亲配,比如雖然系統(tǒng)是64位,但如果PHP是32位的話,那么Oracle instant Client要選用32位的

二吼虎、Linux(redhat6)

(一)下載Oracle instant Client

根據(jù)系統(tǒng)信息去Oracle官網(wǎng)下載相應(yīng)的Oracle instant Client版本犬钢,博主用是的zip包方法,所以下載了相應(yīng)的basic包思灰,即instantclient-basic-linux.x64-12.2.0.1.0.zip玷犹、 SDK包,即instantclient-sdk-linux.x64-12.2.0.1.0.zip

(二)下載php_oci8源碼包

根據(jù)phpinfo()的信息洒疚,前往oci8拓展下載相應(yīng)版本的源碼包歹颓,博主用的是PHP7,因此下載的是oci8-2.1.4.tgz

(三)安裝

將Oracle instant Client的sdk包和basic包解壓到同一目錄油湖,例如我解壓到/opt巍扛,合并成/opt/instantclient_12_2目錄。

[root@rhl6 opt]# unzip instantclient-basic-linux.x64-12.2.0.1.0.zip
[root@rhl6 opt]# unzip instantclient-sdk-linux.x64-12.2.0.1.0.zip
[root@rhl6 opt]# ls
instantclient_12_2

然后解壓并編譯oci8-2.1.4.tgz乏德,注意編譯參數(shù)的目錄要跟你所解壓的Oracle instant Client Lib目錄對(duì)應(yīng)

[root@rhl6 opt]# tar zxvf oci8-2.1.4.tgz
[root@rhl6 opt]# cd oci8-2.1.4
[root@rhl6 opt]# phpize
[root@rhl6 opt]# ./configure -with-oci8=instantclient,/opt/instantclient_12_2
[root@rhl6 opt]# make && make install

安裝完成后在php.ini加入extension=oci8.so并且重新加載php-fpm/etc/init.d/php-fpm reload即可完成oci8拓展的配置撤奸。

(三)錯(cuò)誤
1.遇到libclntsh.so not found的錯(cuò)誤
給libclntsh.so.*.1做個(gè)軟連接libclntsh.so

[root@rhl6 opt]# cd /opt/instantclient_12_2
[root@rhl6 instantclient_12_2]# ln -s libclntsh.so.12.1 libclntsh.so

三、Demo

// demo.php
$username = 'user';
$password = 'user12345';

// oracle10格式:[//]host_name[:port][/service_name]   示例://192.168.128.28:1521/USERDEV
// oracle11格式:[//]host_name[:port][/service_name][:server_type][/instance_name]   示例://192.168.128.28:1521/USERDEV
$connectText = '//192.168.128.28:1521/USERDEV';

putenv("NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK");
$conn = oci_connect($username, $password, $connectText);
if (!$conn) {
    $e = oci_error();
    echo 'Oracle連接失敗<br />';
    exit($e['message']);
}

echo 'Oracle連接完成';

// Prepare the statement
$stid = oci_parse($conn, "SELECT * FROM MYDB.USER");
if (!$stid) {
    $e = oci_error($conn);
    exit($e['message']);
}

// Perform the logic of the query
$r = oci_execute($stid);
if (!$r) {
    $e = oci_error($stid);
    exit($e['message']);
}
// Fetch the results of the query
print "<table>\n";
while ($row = oci_fetch_array($stid, OCI_ASSOC+OCI_RETURN_NULLS)) {
    print "<tr>\n";
    foreach ($row as $item) {
        $item = ($item !== null ? mb_convert_encoding($item, 'utf-8', 'gbk') : " ");
        print "    <td>" . $item . "</td>\n";
    }
    print "</tr>\n";
}
print "</table>\n";
oci_free_statement($stid);
oci_close($conn);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末喊括,一起剝皮案震驚了整個(gè)濱河市胧瓜,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌郑什,老刑警劉巖府喳,帶你破解...
    沈念sama閱讀 223,126評(píng)論 6 520
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異蹦误,居然都是意外死亡劫拢,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,421評(píng)論 3 400
  • 文/潘曉璐 我一進(jìn)店門(mén)强胰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)舱沧,“玉大人,你說(shuō)我怎么就攤上這事偶洋∈炖簦” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,941評(píng)論 0 366
  • 文/不壞的土叔 我叫張陵玄窝,是天一觀的道長(zhǎng)牵寺。 經(jīng)常有香客問(wèn)我,道長(zhǎng)恩脂,這世上最難降的妖魔是什么帽氓? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,294評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮俩块,結(jié)果婚禮上黎休,老公的妹妹穿的比我還像新娘浓领。我一直安慰自己,他們只是感情好势腮,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,295評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布联贩。 她就那樣靜靜地躺著,像睡著了一般捎拯。 火紅的嫁衣襯著肌膚如雪泪幌。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,874評(píng)論 1 314
  • 那天署照,我揣著相機(jī)與錄音祸泪,去河邊找鬼。 笑死藤树,一個(gè)胖子當(dāng)著我的面吹牛浴滴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播岁钓,決...
    沈念sama閱讀 41,285評(píng)論 3 424
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼升略,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了屡限?” 一聲冷哼從身側(cè)響起品嚣,我...
    開(kāi)封第一講書(shū)人閱讀 40,249評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎钧大,沒(méi)想到半個(gè)月后翰撑,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,760評(píng)論 1 321
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡啊央,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,840評(píng)論 3 343
  • 正文 我和宋清朗相戀三年眶诈,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓜饥。...
    茶點(diǎn)故事閱讀 40,973評(píng)論 1 354
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡逝撬,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出乓土,到底是詐尸還是另有隱情宪潮,我是刑警寧澤,帶...
    沈念sama閱讀 36,631評(píng)論 5 351
  • 正文 年R本政府宣布趣苏,位于F島的核電站狡相,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏食磕。R本人自食惡果不足惜尽棕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,315評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望彬伦。 院中可真熱鬧滔悉,春花似錦蟀悦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,797評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)询张。三九已至孙乖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間份氧,已是汗流浹背唯袄。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,926評(píng)論 1 275
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蜗帜,地道東北人恋拷。 一個(gè)月前我還...
    沈念sama閱讀 49,431評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像厅缺,于是被迫代替她去往敵國(guó)和親蔬顾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,982評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容