内容简介:b) TRUNCATE TABLE
ORA-02266: unique/primary keys in table referenced by enabled foreign keys 这篇博客是很早之前总结的一篇文章,最近导数时使用 TRUNCATE 清理主表数据又遇到了这个错误,发现还有其它解决方案:
a) 禁用与主表相关的外键约束
b) TRUNCATE TABLE
c) 启用那些外键约束。
在实际操作中,发现使用上面的流程操作虽然正确,但是要写很多脚本,有些主表中的字段可能是多个表的外键约束。那么我们必须写多个脚本,那么我们必须使用脚本批量生成。具体如下所示:。
-- 生成禁用约束的脚本 , 解决 ORA-02266: unique/primary keys in table referenced by enabled foreign keys
SELECT DC.OWNER AS "PARENT_TABLE_OWNER", DC.TABLE_NAME AS "PARENT_TABLE_NAME", DC.CONSTRAINT_NAME AS "PRIMARY CONSTRAINT NAME", DF.CONSTRAINT_NAME AS "REFERENCED CONSTRAINT NAME", DF.OWNER AS "CHILD_TABLE_OWNER", DF.TABLE_NAME AS "CHILD_TABLE_NAME" , 'ALTER TABLE ' || DF.OWNER || '.' || DF.TABLE_NAME || ' DISABLE CONSTRAINT ' || DF.CONSTRAINT_NAME || ';' FROM DBA_CONSTRAINTS DC, (SELECT C.OWNER, C.CONSTRAINT_NAME, C.R_CONSTRAINT_NAME, C.TABLE_NAME FROM DBA_CONSTRAINTS C WHERE CONSTRAINT_TYPE = 'R') DF WHERE DC.CONSTRAINT_NAME = DF.R_CONSTRAINT_NAME AND DC.OWNER =UPPER('&OWNER') AND DC.TABLE_NAME=UPPER('&TABLE_NAME');
-- 生成启用约束的脚本 , 解决 ORA-02266: unique/primary keys in table referenced by enabled foreign keys
SELECT DC.OWNER AS "PARENT_TABLE_OWNER", DC.TABLE_NAME AS "PARENT_TABLE_NAME", DC.CONSTRAINT_NAME AS "PRIMARY CONSTRAINT NAME", DF.CONSTRAINT_NAME AS "REFERENCED CONSTRAINT NAME", DF.OWNER AS "CHILD_TABLE_OWNER", DF.TABLE_NAME AS "CHILD_TABLE_NAME" , 'ALTER TABLE ' || DF.OWNER || '.' || DF.TABLE_NAME || ' ENABLE CONSTRAINT ' || DF.CONSTRAINT_NAME || ';' FROM DBA_CONSTRAINTS DC, (SELECT C.OWNER, C.CONSTRAINT_NAME, C.R_CONSTRAINT_NAME, C.TABLE_NAME FROM DBA_CONSTRAINTS C WHERE CONSTRAINT_TYPE = 'R') DF WHERE DC.CONSTRAINT_NAME = DF.R_CONSTRAINT_NAME AND DC.OWNER =UPPER('&OWNER') AND DC.TABLE_NAME=UPPER('&TABLE_NAME');
原因分析:对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE ,因为 TRUNCATE 不会触发触发器,不会去验证任何约束。所以语法上是不允许的:有外键约束的表只能用DELETE,不能用TRUNCATE。
You cannot truncate a table with an enabled foreign key that points to it. Truncate does not fire any triggers, does not validate any constraints. It does not care of the child table is empty or not -- in this case the child table might actually not be empty.
以上所述就是小编给大家介绍的《ORA-02266错误的批量解决方案》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- glibc升级导致系统段错误问题解决方案 荐
- Tomcat 访问Manager APP报403错误解决方案
- SQL Server 连接服务器错误的解决方案
- Go 自定义日期时间格式解析解决方案 - 解决 `parsing time xx as xx` 错误
- 使用PLSQL客户端登录Oracle时报ORA-12502和ORA-12545错误的解决方案
- Hadoop伪分布式下HBase出现at org.jruby.xxxxx错误的解决方案
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
文明之光(第四册)
吴军 / 人民邮电出版社 / 2017-3 / 69.00元
计算机科学家吴军博士继创作《浪潮之巅》、《数学之美》之后,将视角拉回到人类文明史,以他独具的观点从对人类文明产生了重大影响却在过去被忽略的历史故事里,选择了有意思的几十个片段特写,有机地展现了一幅人类文明发展的画卷。《文明之光》系列创作历经整整四年,本书为其第四卷。 作者所选的创作素材来自于十几年来在世界各地的所见所闻,对其内容都有着深刻的体会和认识。《文明之光》系列第四册每个章节依然相对独......一起来看看 《文明之光(第四册)》 这本书的介绍吧!