oracle显示中文乱码

当Oracle客户端和服务端的编码字符集不一致时,会出现中文乱码问题。解决方法包括查看并设置客户端和服务端的NLS_LANG参数,确保字符集兼容。在Windows和Linux环境下,可以通过特定命令查看系统编码,并在注册表或bash_profile文件中设置NLS_LANG,以匹配相应的字符集。
摘要由CSDN通过智能技术生成

oracle显示中文乱码

问题描述:

windows下安装oralce客户端,编码为
SIMPLIFIED CHINESE_CHINA.AL32UTF8
redhat6下安装oracle 11g rac服务端,编码为
AMERICAN_AMERICA.AL32UTF8
客户端插入中文数据,服务端显示乱码,客户端显示正常
服务端插入中文数据,服务端显示乱码,客户端显示乱码

分析:

导致中文乱码的产生的原因是客户端和服务端的编码字符集不统一。数据传输过程的字符集转换取决于参数NLS_LANG。前提是服务端的字符集是客户端字符集的超集。
如果客户端和服务端的NLS_LANG设置相同,则不会发生字符集转换,就会造成客户端插入的中文数据显示正常,但是在服务器为乱码。

解决:

由下面的检查发现是由于服务端未设置NLS_LANG参数,导致服务端的sqlplus操作插入和查询(相当于自己同时也是客户端)时不能合适的转换中文数据

NLS_LANG参数由以下部分组成:
NLS_LANG=_.
NLS_LANG各部分含义如下:
LANGUAGE指定:
-Oracle消息使用的语言
-日期中月份和日显示
TERRITORY指定
-货币和数字格式
-地区和计算星期及日期的习惯
CHARACTERSET:
-控制客户端应用程序使用的字符集
通常设置或者等于客户端(如Windows)代码页
或者对于unicode应用设置为UTF8

1.查看系统编码:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值