linux连接oracle数据库中文显示乱码

问题背景:

orclae服务的原本就是有也使用正常,win下的pl/sql developer客户端能正常访问且,中文字段也显示正常。unix的aix服务器访问oracle用occi和sqlplus也能正常显示中文字段。
后来由于需求需要新增了一台新的linux机子,他的数据库还是使用现有oracle数据库(上面说到的那个数据库)。

问题现象:

linux下的用OCCI查询数据库中文字段getString()中文字段返回???乱码,后来用sqlplus连接orcle用查询语句查询sqlplus查询oracle中文字段也是返回???乱码.

问题分析:

网上查阅资料初步认定是环境字符集编码问题。然后找了下查询oracle客户端字符集编码语句,select * from nls_instance_parameters和select userenv('language') from dual; ,发现linux下的sqlplus和unix下sqlplus及win下pl/sql查询的结果一样。这下郁闷了。后来无心再原本的unix环境里查看了下LANG相关的环境变量发现比linux下多了个NLS_LANG,上网搜索了下得知:NLS_LANG环境变量是oralce客户端字符集配置,ok解决了。

解决

在linux下新增一个环境变量NLS_LANG="american_america.zhs16gbk" ;

转载于:https://www.cnblogs.com/tb131328/p/6214098.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值