IMP-00019

报错

IMP-00019: 由于 ORACLE 错误 12899 而拒绝行

IMP-00003: 遇到 ORACLE 错误 12899

ORA-12899: 列 "XX"."XX"."XXX" 的值太大 (实际值: 21, 最大值: 20)

【一个汉字用GBK存放是2个字符,用AL32UTF8占用3个字符,所以在由ZHS16GBK字符集编码的数据库导出的DMP文件导入到由AL32UTF8字符集编码的数据库
时有的表就会提示"字符过长",导入不成功!】

原因

数据库gbk和utf占用字符不一样,修改数据库字符编码

解决办法

$sqlplus /nolog   

SQL>conn / as sysdba

SQL>shutdown immediate

SQL>STARTUP MOUNT

SQL>ALTER SYSTEM ENABLE RESTRICTED SESSION;

SQL>ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;

SQL>ALTER SYSTEM SET AQ_TM_PROCESSES=0;

SQL>ALTER DATABASE OPEN;

SQL>ALTER DATABASE CHARACTER SET ZHS16GBK;

ERROR at line 1:ORA-12721: operation cannot execute when other sessions are active

若出现上面的错误,使用下面的办法进行修改,使用INTERNAL_USE可以跳过超集的检查:

SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;

SQL>SHUTDOWN IMMEDIATE;

SQL>STARTUP;

 

再次导入,问题解决。

你可能感兴趣的:(oracle,oracle)