oracle中文显示???解决方法

oracle中文显示???解决方法

问题描述:
中文字段查询显示为???
在这里插入图片描述
解决思路:

1、查询数据库字符集

select userenv('language') from dual;

在这里插入图片描述

2、查询客户端字符集

echo $NLS_LANG        //与数据库字符集不一致或为空

在这里插入图片描述
可以看到数据库字符集与客户端的字符集不一致。

解决方法:
如果客户端与数据库的字符集不一致,解决方法如下(选其一进行修改):

1)修改数据库字符集和客户端的一致
修改Oracle服务器端的字符集

SQL> shutdown immediate
SQL> startup nomount
SQL> alter database mount exclusive;           //装载数据为专用的高级模式;
SQL> alter system enable restricted session;   //启用受限制的session模式
SQL> alter system set job_queue_processes=0;   //'maximum number of job queue slave processes' 设置工作队列的最大进程数为0
SQL> alter system set aq_tm_processes=0;
SQL> alter database open;
SQL> alter database character set INTERNAL_USE  AL32UTF8;  // 或者设置为ZHS16GBK   alter database character set INTERNAL_USE ZHS16GBK;
SQL> shutdown immediate
SQL> startup

2)或修改客户端和数据库的字符集一致

vi ~/.bash_profile         //修改如下图NLS_LANG的值与数据库字符集一致
source ~/.bash_profile     //修改完之后记得生效

在这里插入图片描述
PS: 需要注意的是,对于之前已经存在的数据,在修改了字符集之后还是会显示为乱码,只有新插入的数值才会生效。

可以看出之前插入的中尉已经显示为?,新插入的汉字显示正常
在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值