php操作oracle查询时中文乱码

kasonbin 发布于 2012/07/22 16:32
阅读 6K+
收藏 0
环境:
oracle数据库是安装在xp上。
版本:10.2.0.3
NLS_LANGUAGE
AMERICAN

NLS_TERRITORY
AMERICA

NLS_CHARACTERSET
ZHS16GBK

一、sqlplus客户端操作数据库(客户端操作语言环境为SIMPLIFIED CHINESE_CHINA.ZHS16GBK):
1、
cmd
set NLS_LANG=American_America.ZHS16GBK
sqlplus /nolog
conn scott/tiger@salesnew
insert into emp values('7777','你','好','7709','1-11月-2012','5000','800','20');
commit;
select * from emp;

  EMPNO ENAME JOB MGR HIREDATE SAL COMM
---------- ---------- --------- ---------- ------------ ---------- ----------
  DEPTNO
----------
  7777 你 好 7709 01-NOV-12 5000 800
  20
结论:我录入的数据库是没有问题的。

二、php通过oci操作oracle
1、php所以操作及环境为windows 2003 x86 企业版简体中文+iis6.0+oracle instantclient-basic-win32-10.2.0.4.zip+fcgisetup_1.5_rtw_x86.msi
2、配置完所有必需的环境后,测试了
<?php
  phpinfo();
?>
显示一切正常
3、开始操作oracle


<?php
echo oci_client_version ();

//header('Content-type: text/html; charset=ZHS16GBK');
//set NLS_LANG=American_America.ZHS16GBK
//export NLS_LANG=American_America.ZHS16GBK
//putenv("NLS_LANG=American_America.ZHS16GBK");

$conn = oci_connect('scott', 'tiger', '192.168.1.50/salesnew','ZHS16GBK');
if (!$conn) {
  $e = oci_error();
  trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR);
   
}
echo oci_server_version ($conn);
// Prepare the statement
$stid = oci_parse($conn, 'SELECT * FROM emp');
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);
echo "测试页面本身中文显示情况";
?> 

中文部分乱码
如下所示:

10.2.0.4.0Oracle Database 10g Enterprise Edition Release 10.2.0.3.0 - Production With the Partitioning, OLAP and Data Mining options
7777 Ä㠺à 7709 01-NOV-12 5000 800 20 
8888 ÖÓ º£ 7709 01-NOV-10 5000 800 20 
9999 Àî ¾ê 8888 01-JAN-11 3000 5000 20 
7369 SMITH CLERK 7902 17-DEC-80 800 20 
7499 ALLEN SALESMAN 7698 20-FEB-81 1600 300 30 
7521 WARD SALESMAN 7698 22-FEB-81 1250 500 30 
7566 JONES MANAGER 7839 02-APR-81 2975 20 
7654 MARTIN SALESMAN 7698 28-SEP-81 1250 1400 30 
7698 BLAKE MANAGER 7839 01-MAY-81 2850 30 
7782 CLARK MANAGER 7839 09-JUN-81 2450 10 
7788 SCOTT ANALYST 7566 19-APR-87 3000 20 
7839 KING PRESIDENT 17-NOV-81 5000 10 
7844 TURNER SALESMAN 7698 08-SEP-81 1500 0 30 
7876 ADAMS CLERK 7788 23-MAY-87 1100 20 
7900 JAMES CLERK 7698 03-DEC-81 950 30 
7902 FORD ANALYST 7566 03-DEC-81 3000 20 
7934 MILLER CLERK 7782 23-JAN-82 1300 10 
测试页面本身中文显示情况 


这一个问题已经折腾我快疯了,百度、谷歌了好几天都解决不了这个问题。
尝试过以下方法
1、设置php环境所在的操作系统环境变量NLS_LAGN=SIMPLIFIED CHINESE_CHINA.ZHS16GBK或NLS_LANG=American_America.ZHS16GBK。
2、$conn = oci_connect('scott', 'tiger', '192.168.1.50/salesnew','AL32UTF8');也不行
3、header('Content-type: text/html; charset=ZHS16GBK');或<meta/>都试过了也无果。

看几遍ORACLE关于字符集的相关知识以及PHP官方文档,还是不知道怎么去解决。按照oracle官方文档的说法,我在sqlplus客户端所insert进去的数据库是正确的。只是到了PHP这头的处理就不对了。也尝试过用iconv函数对$item结果进行字符集编码的转换也是没能正常的显示中文。另外使用第三方工具PL/SQL连接oracle查询出来的数据是正常的没有乱码。

实在没办法请求大家的帮助和交流,比较紧急,这是一个真实的项目。
加载中
1
g
gary
putenv("NLS_LANG=American_America.ZHS16GBK"); 
yybawang
yybawang
putenv("LD_LIBRARY_PATH=/usr/lib/oracle/12.1/client64/lib"); putenv("ORACLE_HOME=/usr/lib/oracle/12.1/client64"); putenv("NLS_LANG=AMERICAN_AMERICA.AL32UTF8"); 亲测成功,再也不担心脚本插库乱码了
0
TYi
TYi
network 目录 的 ora链接文件有无修改文字配置呢?
0
kasonbin
kasonbin

不是很明白你的意思??你是指数据库服务器端的listener.ora或tnsnames.ora?还是别的什么文件??可以说清楚的吗??

0
IdleMan
IdleMan
问题可能出在驱动上。上次我也遇到了乱码的情况,换了个oracle client版本就好了。
0
kasonbin
kasonbin

问题已经找到了,做一个很愚蠢的事情。上面那一段PHP代码是我为了省事,直接复制PHP官方手册上面的来进行测试。一直没看print后面那一段代码

0
cherry_01
cherry_01
楼上能不能说说如何解决啊哈?
0
cherry_01
cherry_01

哈哈我已经解决问题了。

0
高手
将  htmlentities  修改成 htmlspecialchars就可以了。htmlentities  使用中文会出现乱码
0
杀神启示
这就是这个社区,这就是祖国的程序员,好几个都解决了,没一个人说解决方法
返回顶部
顶部