ORA-02292违反完整约束和ORA-02297无法禁用约束条件 cascade禁用主键

本文详细介绍了在Oracle数据库中遇到ORA-02292错误时的解决方法,该错误通常发生在尝试删除具有主键或外键约束的记录时。文章提供了禁用和重新启用约束的具体SQL语句,包括使用CASCADE选项来级联修改约束。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29863023/viewspace-1352988/

ORACLE 中delete时出现ORA-02292:违反完整约束条件 错误

该表中存在主键或外键,可以先禁用。
于是用: alter table hx_tb.tabs modify constraint FK_fk1 disable;
              alter table hx_ta.tabs modify constraint PK_pk1 disable;

我用的是:

ALTER TABLE ES_SYSTEM.FUNC_DEF DISABLE CONSTRAINT PK_FUNC_DEF CASCADE;

发现禁用主键 PK_pk1 时 提示ORA-02297:无法禁用约束条件 -存在相关性
说明该表的主键被其他表作为了外键,置约束无效得加上cascade;

cascade:
级联删除,比如你删除某个表的时候后面加这个关键字 会在删除这个表的同时删除和该表有关系的其他对象

于是可以 alter table hx_ta.tabs modify constraint PK_pk1 disable cascade; 可成功禁用!

执行完delete 操作后,执行:
              alter table hx_tb.tabs modify constraint FK_fk1 enable;
              alter table hx_ta.tabs modify constraint PK_pk1 enable;

我用的是:
ALTER TABLE ES_SYSTEM.FUNC_DEF MODIFY CONSTRAINT PK_FUNC_DEF ENABLE;

转载于:https://www.cnblogs.com/shizilunya/p/9921930.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值