彻底搞懂oracle字符集,搞懂Oracle字符集的几个要点

经常会遇到一些“为什么我的查询显示乱码?”或者“为什么我导入后中文变成乱码?”的问题,如果想彻底搞懂原因,需要研究下Oracle的字符集以及他们之间的转换的关系,还有OS字符集、NLS_LANG跟数据库字符集的关系。简单的总结下要搞懂的几个要点:

1. NLS_LANG数据库:保证字符相同,存储的2进制可变。

OSNLS_LANG:存储的2进制不变,字符可能显示不同。

2. 如果NLS_LANG设置成跟数据库字符集一样,则通过ORACLE NET传递数据时存储的2进制不会发生转换。如果不一样,则会发生转换。

3. NLS_LANG并不是我们以为的用来显示给我们的字符的编码,真正用来显示的编码是OS编码,所以如果NLS_LANG跟OS编码不一样时,同一个2进制串可能就会由本来的‘你’显示成‘靠’。

4. 向数据库传递字符时应尽量将NLS_LANG设置成OS字符集,以保证输入的‘我’到NLS_LANG一层不会发生字符变化,从而保证到数据库端存储的就是‘我’;

不过使用EXP等客户端工具导出时,应尽量将NLS_LANG设置成数据库字符集,以保证导出时数据原封不动,不会发生数据丢失的可能。导入时也应尽量将NLS_LANG设成导出文件的字符集,以保证将转换移至传输到数据库的一步。(EXP,IMP也可能会发生数据丢失问题,具体要看源数据库,EXP客户端NLS_LANG,IMP客户端NLS_LANG,目标数据库的字符集)

5.其实乱码,说到底就是用于显示字符的操作系统没有在字符编码中找到对应的字符导致的,也并不是只要将NLS_LANG设置成数据库字符集就可以避免乱码的。

贴两张EYGLE的转换图:

663e30d430442bf123b8def96181c687.png

c8c85d5f8068fccdf84e5dfea6aa9760.png0b1331709591d260c1c78e86d0c51c18.png

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值