ORA-12899:value too large for column

DMP文件导入过程中报错

问题起始:同样的文件导另一库报错
问题根源:数据库服务端字符集问题
问题解决:AL32UTF8转换为ZHX16GBK即可
转换参考链接:https://blog.csdn.net/iamlaosong/article/details/52316844

数据导入时报ORA-12899错误,即插入的数据长度超出字段的设置长度,实际长度并不长,这是由于Oracle字符集不同,汉字占的长度不同造成的。中文在ZHS16GBK中占2个字节,在UTF-8中却占3个字节,所以汉字导入UTF-8字符集的数据库就很容易出现字段长度不够,解决办法,一个是增加字段长度,还有就是修改字符集。如果系统中已经存在很多数据,建议修改字段长度,因为修改字符集后原来数据库表中的汉字全部变成乱码。如果一定要修改字符集,必须先导出数据,待到字符集修改后再重新导入这些数据。
如上图所示,字符集是UTF-8,修改字符集的方法如下:
修改数据库字符集为:ZHS16GBK
查看服务器端字符集SQL > select * from V N L S P A R A M E T E R S T e l n e t NLS_PARAMETERS Telnet到服务器,执行: sqlplus /nolog
SQL>conn / as sysdba
若此时数据库服务器已启动,则先执行 SHUTDOWN IMMEDIATE 命令关闭数据库服务器,
然后执行以下命令:
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
作者:宋哥
来源:CSDN
原文:https://blog.csdn.net/iamlaosong/article/details/52316844
版权声明:本文为博主原创文章,转载请附上博文链接!

注:需重启数据库

猜你喜欢

转载自blog.csdn.net/yyqjjw/article/details/88211841