Oracle 数据库下处理Unicode字符

某些情况下,使用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);
}
?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值