您的位置:首页 > 数据库 > Oracle

oracle 11g下exp direct=y的陷阱

2016-09-05 16:15 399 查看
今天同事分享了一个案例

数据库版本是oracle 11G,使用exp导出数据,然后imp导入。

Column :

Column :

Column :

IMP-00019: row rejected due to ORACLE error 1400

IMP-00003: ORACLE error 1400 encountered

ORA-01400: cannot insert NULL into ("HSVSDATA"."TFJYGH"."EN_LXSDS")

从生产导一个属主到测试,使用了Direct=y导出,结果导入报如上错误,原因是如下:

原因是11g的一个新特性:为了改善性能,对表新增非空且有缺省值列的时候,ORACLE不会全表更新,只是改了数据字典,这种情况下,exp如果加了参数direct=y导致了丢失了字段值.不会导出字段的缺省值,所以报错了。

11g下的exp 还是别加direct=y 了。


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: