Oracle查询表之间的主外键关系

一、在已经有的项目系统开发,如果数据库设计,表与表之间建立了外键约束,那么删除时就要去删对应约束列

1、查询对于应表中的主键是哪些表的外键,以test表为例

select c.TABLE_NAME
  from all_constraints p, all_constraints c
 where p.table_name = upper('test')
   and p.OWNER = SYS_CONTEXT('USERENV', 'CURRENT_SCHEMA')
   and c.OWNER = SYS_CONTEXT('USERENV', 'CURRENT_SCHEMA')
   and c.constraint_type = 'R'
   and p.CONSTRAINT_NAME = c.R_CONSTRAINT_NAME;

2、查询对于应表中的外键来源于哪些表,以test表为例

select cl.table_name  
  from user_cons_columns cl  
  left join user_constraints c  
    on cl.constraint_name = c.r_constraint_name  
 where c.constraint_type = 'R'  
   and c.table_name = upper('test');

 

yexiangyang

moyyexy@gmail.com


 

 

转载于:https://www.cnblogs.com/moy25/p/8610502.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值