溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在windwos環(huán)境中使用php連接oracle數(shù)據(jù)庫

發(fā)布時(shí)間:2021-02-08 16:19:58 來源:億速云 閱讀:200 作者:Leah 欄目:開發(fā)技術(shù)

怎么在windwos環(huán)境中使用php連接oracle數(shù)據(jù)庫?針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

要使用php連接oracle,基本條件是
1.需要你安裝了php、
2.安裝了oracle、
3.配置了tnsname.ora。
本地命令行使用sqlplus能夠連接到oracle。

根據(jù)你機(jī)器的版本選對64bit或者32bit的php程序,我們使用php的oci8擴(kuò)展連接oracle

安裝好php后,打開oci8擴(kuò)展,

寫一段連接oracle的ora.php代碼

復(fù)制代碼 代碼如下:


<?php

$conn = oci_connect('hr', 'welcome', 'MYDB');
if (!$conn) {
    $e = oci_error();
    trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}

// Prepare the statement
$stid = oci_parse($conn, 'SELECT * FROM departments');
if (!$stid) {
    $e = oci_error($conn);
    trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}

// Perform the logic of the query
$r = oci_execute($stid);
if (!$r) {
    $e = oci_error($stid);
    trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
}

// Fetch the results of the query
print "<table border='1'>\n";
while ($row = oci_fetch_array($stid, OCI_ASSOC+OCI_RETURN_NULLS)) {
    print "<tr>\n";
    foreach ($row as $item) {
        print "    <td>" . ($item !== null ? htmlentities($item, ENT_QUOTES) : "&nbsp;") . "</td>\n";
    }
    print "</tr>\n";
}
print "</table>\n";

oci_free_statement($stid);
oci_close($conn);

?>

說明:
oci_connect('hr', 'welcome', 'MYDB')
第一個參數(shù)是oracle的用戶名,
第二個參數(shù)是oracle的密碼
第三個參數(shù)是tnsnames.ora里的連接串名

命令行下執(zhí)行

復(fù)制代碼 代碼如下:

php ora.php

提示如下錯誤

復(fù)制代碼 代碼如下:


PHP Warning: PHP Startup: Unable to load dynamic library 'C:\php\php_oci8.dll'- %1 不是有效的 Win32 應(yīng)用程序。 in Unknown on line 0
PHP Parse error: syntax error, unexpected '"user"' (T_CONSTANT_ENCAPSED_STRING) in C:\Users\nginx\Desktop\oraclephpoci\oci.php on line 3

開始以為是沒有選對版本,我是64位的機(jī)器,結(jié)果說是win32的程序,一看字面提示,我就重新安裝了新的32bit程序還是報(bào)錯。

仔細(xì)查了查發(fā)現(xiàn)在32位像64位遷移的問題,出現(xiàn)如下問題時(shí),我們需要安裝Oracle Instant Client。

復(fù)制代碼 代碼如下:


Unable to load dynamic library 'C:\Program Files (x86)\PHP\ext\php_oci8_11g.dll' - %1 is not a valid Win32 application.
Warning oci_connect(): OCIEnvNlsCreate() failed. There is something wrong with your system - please check that PATH includes the directory with Oracle Instant Client libraries


Oracle Instant Client,它是一個解壓后就能使用的程序,不需要安裝。

下載后把壓縮包解壓到c:\oracleinstantclient,并添加路徑到環(huán)境變量PATH

重新執(zhí)行php ora.php,“%1 不是有效的 Win32 應(yīng)用程序”的錯誤沒有了,但是會提示

復(fù)制代碼 代碼如下:

syntax error, unexpected T_CONSTANT_ENCAPSED_STRING


代碼是從php官網(wǎng)直接拷過來的,代碼中有不可見的字符,使用notepad++查看所有字符,去掉亂碼即可。

繼續(xù)執(zhí)行,這次提示,

復(fù)制代碼 代碼如下:


PHP Fatal error: ORA-12154: TNS:could not resolve the connect identifier specified in C:\Users\nginx\Desktop\airline\oci.php on line 6


看樣子是php沒有找到tnsnames.ora的位置,時(shí)間比較趕,那我就直接使用ip的形式,具體格式根據(jù)你的信息拼寫oci_connect的第三個參數(shù)
oracle10格式:[//]host_name[:port][/service_name]
oracle11格式:[//]host_name[:port][/service_name][:server_type][/instance_name].
我具體使用的php oci連接串是:

復(fù)制代碼 代碼如下:

$conn = oci_connect('hr', 'welcome', '//www.jb51.net:1523/sycx');

配好上述信息后,終于能出結(jié)果了,但是發(fā)現(xiàn)查出來的結(jié)果中問亂碼,這種問題基本都是編碼不匹配。

php oci8中文亂碼解決辦法,先查詢你的oracle的數(shù)據(jù)庫編碼使用,

復(fù)制代碼 代碼如下:

select userenv('language') from dual;


查出來的結(jié)果是SIMPLIFIED CHINESE_CHINA.ZHS16GBK,在php的代碼里設(shè)置環(huán)境變量

復(fù)制代碼 代碼如下:

putenv("NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK");

終于php能夠正確連接到oracle啦。

關(guān)于怎么在windwos環(huán)境中使用php連接oracle數(shù)據(jù)庫問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI