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: 需要注意的是,对于之前已经存在的数据,在修改了字符集之后还是会显示为乱码,只有新插入的数值才会生效。
可以看出之前插入的中尉已经显示为?,新插入的汉字显示正常