某些情况下,使用PHP OCI8调用Oracle数据库,一些罕见的Unicode字符会被转码为?,即便你使用了AL32UTF8的连接字符集。一般这种情况可能是由于数据库自身的结构设置不对。
为了解决这种情况,可以采用以下折衷办法:
第一步,强制要求OCI将所有字符串返回为ASCII字符,非ASCII字符进行转码:
SELECT ASCIISTR(NVCHAR2_FIELD) AS FIELD FROM TABLE_NAME;
第二步,在PHP程序中,处理这些转码后的字符;
<?
function _private_process_oracle_asciistr($str) {
return preg_replace_callback(
'|\\\([0-9A-F]{4})|',
function ($matches) {
return mb_convert_encoding('&#'.intval('0x'.$matches[1],0).';', 'UTF-8', 'HTML-ENTITIES');
},
$str);
}
?>