PHP 串連 Oracle 出現中文亂碼問題

來源:互聯網
上載者:User
資料庫用 oracle,當 PHP串連 Oracle 的時候,如果指定字元集,會出現中文亂碼。

查PHP手冊,oci_pconnect 的第四個參數為 charset,只需設定這參數即可。

首先擷取 Oracle 的字元集,運行“SELECT * FROM V$NLS_PARAMETERS;”,變數NLS_CHARACTERSET對應的就是我們需要的字元集,比如我這裡就是 “AL32UTF8”。所以,最終的PHP代碼為:

$conn = oci_pconnect('scott','tiger',"(DEscriptION=(ADDRESS=(PROTOCOL =TCP)(HOST=192.168.0.1)(PORT = 1521))(CONNECT_DATA =(SERVER = DEDICATED)(SERVICE_NAME=jocsbk)))",'AL32UTF8');

由於本地的 PHP 檔案統一用 utf-8 ,所以,直接輸出就正常了。不用進行編碼轉換。

另外,據查詢相關資料,如果你本地的檔案跟串連 Oracle 的字元集不相同,還要進行編碼轉換。

while ($dat = oci_fetch_row($cur)) {     print_r(iconv('gb2312', 'utf-8', $dat[0]));   }  //或者while ($dat = oci_fetch_row($cur)) {     print_r(mb_convert_encoding($dat[0], 'utf-8', 'gbk'));   }

也有另外一種解決方式,但沒試過。Oracle 可以按照 用戶端指定的字元集 提供資料。也就是說,如果我本地PHP檔案用UTF-8,那麼,我在oci_connect的時候,直接指定utf-8就行了,連編碼轉換都省了。

$c1 = oci_connect("scott", "tiger", $db, 'UTF8');
  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.