Oracle中出现“名称已被一现有约束条件占用”问题 怎么查找约束?怎么删除约束???

  

今天我在进行本地测试,进行新建表和添加表主键约束操作时出现了如下错误:

“名称已被一现有约束条件占用”

后来经检查发现原来,我原来建立的表MEDIA_TEST表中已经有一个名为PK_MEDIA的约束了,将其改名,然后,修改操作就PASS了。

 

查找约束的方法如下:

1查找某表上的约束

select   *   from   user_constraints 

 where table_name='MEDIA'

2

有时想删除一个表上的记录,由于创建的约束比较多,不知道约束在哪个表上,无法删除记录,CASCADE也不行.

   这时就要找到约束所在的表,可以用以下SQL语句查询出约束所在的表:
   SELECT * FROM USER_CONSTRAINTS
   WHERE CONSTRAINT_NAME = 'CONSTRAINT_NAME';
   
再删除约束所在的表的具有约束限制的记录...

SELECT * FROM USER_CONSTRAINTS

   WHERE CONSTRAINT_NAME = 'PK_MEDIA';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值