Linux oracle中文乱码的问题解决

目录

1.查看客户端的语言编码设置

2.查看数据库使用的编码:修改linux oracle数据库的默认语言

*修改后数据库中原有的数据可能会出现错误,需要重新删除表好重新导入数据


乱码问题的根源是字符集的修改

1.查看linux的默认语言

SQL> select userenv('language') from dual;

USERENV('LANGUAGE')
----------------------------------------------------
AMERICAN_AMERICA.ZHS16GBK

1.查看客户端的语言编码设置

配置文件中的配置: cat  ~/.bash_profile

注意修改配置信息:

export PATH
export ORACLE_HOME=/usr/lib/oracle/11.2/client64/
export LD_LIBRARY_PATH=:$ORACLE_HOME/lib:/usr/local/lib:$LD_LIBRARY_PATH:.
export TNS_ADMIN=$ORACLE_HOME
export PATH=$PATH:$ORACLE_HOME/bin:
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

       配置好后,查看配置是否成功,sql语句:select userenv('language') from dual

2.查看数据库使用的编码:修改linux oracle数据库的默认语言

修改方法(以改成UTF8为例)
以系统DBA权限登录sqlplus
$ sqlplus / as sysdba;
select userenv('language') from dual;
   例如:AMERICAN_AMERICA.WE8MSWIN1252  

修改:
SQL> shutdown immediate;
SQL> startup mount;
SQL> alter system enable restricted session;
SQL> alter system set job_queue_processes=0;
SQL> alter database open;
SQL> alter database character set internal_use AL32UTF8;  (或者  ALTER DATABASE character set INTERNAL_USE ZHS16GBK;)
SQL> shutdown immediate;
SQL> startup
SQL>alter system disable restricted session;

*修改后数据库中原有的数据可能会出现错误,需要重新删除表好重新导入数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小旋哥^^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值