数据库字符集 AMERICAN_AMERICA.WE8ISO8859P1
如果我不设置数据库第四个参数返回的中文信息为null,如果将第四个参数设置为utf8 返回乱码,代码如下
直接上代码
<?php
header('Content-type:application/json;charset=utf-8');
putenv("NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1");
$Oracle_conn=oci_connect('user','pass','db','utf8');
$query="Select CMNAME,CDMMKT,CDMNO,CDMTYPE, CDMSTATUS,CDMFLAG,CDMCID,CCURJFYE CDMJF, CTOTXFJE CDMXFJE, NVL(CDMZHYE1, 0) CDMZHYE1, CMNAME,CMBIRTHDAY,CMIDNO, CMMOBILE1,CMLCZHYE From CARDMAIN,CUSTMEMBER, CUSTOMER Where CDMOWNER=CMMEMID And CDMCID = CID and cdmno = '" . $_GET["ds"] ."'";
$statement=oci_parse($Oracle_conn,$query);
//执行语句;
oci_execute($statement);
//取得结果数据;
while (($row = oci_fetch_object ($statement)) != false) {
//var_dump($row);
echo json_encode($row);
}
//释放资源;
oci_free_statement($statement);
oci_close($Oracle_conn);
?>
分割线------------------------------------
以上代码查询ORACLE正常,但是库里有中文时显示乱码,以下为查询结果
因数据库内有大量数据,无法修改字符集,有没有什么办法能在不修改数据库字符集的情况下中文能正常显示,
请大神们不灵赐教