linux安装Oracle中文乱码问题汇总
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了linux安装Oracle中文乱码问题汇总,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2341字,纯文字阅读大概需要4分钟。
内容图文
![linux安装Oracle中文乱码问题汇总](/upload/InfoBanner/zyjiaocheng/477/9c2ed8bc726749ae9b53bec77e0fee44.jpg)
解决oracle中文显示乱码有三层地方需要调整或者修改
第一层:操作系统层
1.首先查看linux是否有安装中文字符集,
locale -a
2.设置用户的中文字符集
查看到linux安装了中文字符集,那么oracle用户下面要设置中文字符集
vi /etc/locale.conf # centos7是这个配置文件,有的linux是这个配置文件/etc/sysconfig/i18n LANG="zh_CN.UTF-8"
上面的那种方法设置完后,系统所有用户的字符集都是UTF-8。也可以改带个用户的字符集,就是在用户下的环境变量配置文件里面.bashrc里面直接
export LANG="zh_CN.UTF-8"
第二层:数据库层
在数据库里面查询数据库和实例的字符集
select * from nls_database_parameters; select * from nls_instance_parameters;
可以看到数据库的字符集是ZHS16GBK,ok;要保持服务端和客户端的字符集一致
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
这样之后,那我们打开sqlplus 查询中文,一般就能正常显示了,如果还是乱码,那就新insert一个中文看看,因为修改之前的字符编码跟修改之后的不一致,比如插进去的时候是UTF8解析的,现在改为gbk那么解析就是乱码咯。(sqlplus能正常显示中文之后,我们离胜利更近了一步)。
第三层:plsql层(windows层)
有的人碰到,sqlplus能正常显示中文,但是自己windows里面安装的plsql查询中文就是乱码。(问题就在这里了,我们要解开中文乱码的面纱了)
我们要理解 ,导致中文乱码的原因是什么?是客户端和服务端的中文字符集不一致导致的,这个很好理解两个人说话要用同一种语言(字符集),你说广东话我说闽南语那肯定就很乱咯(乱码),因为解析出错嘛(服务端或者客户端都会解析出错)。
所以,第二层里面在环境变量里面设置
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
就是设置的客户端的字符集,跟数据库保持了一致。那我们windows plsql 也是客户端嘛,所以也要设置NLS_LANG这个环境变量。不罗嗦,上图。
只要是 ZHS16GBK就行了,美国还是中国的这个无所谓。
如上三层,oracle乱码字符集的问题基本就解决了,还有就是这次我示例里面oracle数据库里面的字符集是ZHS16GBK,有的人安装的时候设置的是UTF8的,那么客户端就要设置成UTF8的。并且oracle数据库的字符集是可以修改的,这个修改方法可以去google。
本文出自 “改变世界” 博客,请务必保留此出处http://wongsong.blog.51cto.com/6040075/1905243
linux安装Oracle中文乱码问题汇总
标签:oracle
本文系统来源:http://wongsong.blog.51cto.com/6040075/1905243
内容总结
以上是互联网集市为您收集整理的linux安装Oracle中文乱码问题汇总全部内容,希望文章能够帮你解决linux安装Oracle中文乱码问题汇总所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。