当前位置 : 主页 > 操作系统 > centos >

linux oracle数据乱码怎么办

来源:互联网 收集:自由互联 发布时间:2022-05-02
linux oracle数据乱码的解决办法:1、查看linux的默认语言;2、查看客户端的语言编码设置;3、修改linux oracle数据库的默认语言为UTF8即可。 本文操作环境:linux5.9.8系统、Oracle Database 20c、

linux oracle数据乱码的解决办法:1、查看linux的默认语言;2、查看客户端的语言编码设置;3、修改linux oracle数据库的默认语言为UTF8即可。

本文操作环境:linux5.9.8系统、Oracle Database 20c、Dell G3电脑。

linux oracle数据乱码怎么办?

Linux oracle中文乱码的问题解决

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

1.查看linux的默认语言

0b04f969b8b18567635a51698ed317a.png

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

  配置文件中的配置: 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

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

linux 安装oracle默认语言为:

AMERICAN_AMERICA.WE8MSWIN1252

此语言中文展示位乱码。

通过oracle登录linux系统后进行如下操作:

修改方法(以改成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;

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

推荐学习:《linux视频教程》

以上就是linux oracle数据乱码怎么办的详细内容,更多请关注自由互联其它相关文章!

上一篇:linux不产生core文件怎么办
下一篇:没有了
网友评论