oracle linux 修改字符集

  1. select userenv('language') from dual; //查看系统字符集编码
  2. select * from nls_database_parameters where parameter in ('NLS_CHARCTERSET','NLS_NCHAR_CHARACTERSET');
  3. shutdown immediate
  4. startup
  5. alter session set sql_trace=true;
  6. alter system enable restricted session;
  7. show parameter job_queue_processes;
  8. alter system set job_queue_processes=0;
  9. alter system set aq_tm_processes=0;
  10. alter database character set INTERNAL_USE AL32UTF8;
  11. update props$ set VALUE$='UTF8' where NAME='NLS_NCHAR_CHARACTERSET';

 

 

数据导入时报ORA-12899错误,即插入的数据长度超出字段的设置长度,实际长度并不长,这是由于Oracle字符集不同,汉字占的长度不同造成的。中文在ZHS16GBK中占2个字节,在UTF-8中却占3个字节,所以汉字导入UTF-8字符集的数据库就很容易出现字段长度不够,解决办法,一个是增加字段长度,还有就是修改字符集。

如果系统中已经存在很多数据,建议修改字段长度,因为修改字符集后原来数据库表中的汉字全部变成乱码。如果一定要修改字符集,必须先导出数据,待到字符集修改后再重新导入这些数据。

查看字符集的方法可以用PL/SQL DEVELOP ----Reports----DBA----NLS Database Parameters,结果如下图:

如上图所示,字符集是UTF-8,修改字符集的方法如下:

修改数据库字符集为:ZHS16GBK
查看服务器端字符集SQL select * from V$NLS_PARAMETERS
Telnet到服务器,执行:$sqlplus /nolog
SQLconn / as sysdba
若此时数据库服务器已启动,则先执行 SHUTDOWN IMMEDIATE 命令关闭数据库服务器,
然后执行以下命令:
SQLshutdown immediate
SQLSTARTUP MOUNT
SQLALTER SYSTEM ENABLE RESTRICTED SESSION;
SQLALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
SQLALTER SYSTEM SET AQ_TM_PROCESSES=0;
SQLALTER DATABASE OPEN;
SQLALTER DATABASE CHARACTER SET ZHS16GBK;
ERROR at line 1:ORA-12721: operation cannot execute when other sessions are active
若出现上面的错误,使用下面的办法进行修改,使用INTERNAL_USE可以跳过超集的检查:
SQLALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;
SQLSHUTDOWN IMMEDIATE
SQLSTARTUP

至此,字符集修改完毕,再查字符集,结果如下:

 

 

 

 

最新回复(0)
/jishun_2FMtCWuwSu0hf_2B1z6FmHmGtjNuciYFFizbaI62AhJ8I_3D4858579
8 简首页