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