查询表的PK,FK,TABLENAME

本文介绍了一种通过SQL查询来获取Oracle数据库中表的主键和外键信息的方法。利用user_constraints和其他相关视图,可以有效地列出指定表的所有主键及与其关联的外键信息。

       看到很多在群里问如何查找表的主键,外键,其实最主要是的要了解  

       user_constraints的结构。下面可以实现。

 

       SQL> col 外键拥有者 format a10
  SQL> col 外键表 format a10
  SQL> col 主键拥有者 format a10
  SQL> col 主键表 format a10
  SQL> col 外键列 format a15
  SQL> col 主键列 format a15
  
  select
  a.owner 外键拥有者,
  a.table_name 外键表,
  c.column_name 外键列,
  b.owner 主键拥有者,
  b.table_name 主键表,
  d.column_name 主键列
  from
  user_constraints a,
  user_constraints b,
  user_cons_columns c,
  user_cons_columns d
  where
  a.r_constraint_name=b.constraint_name
  and a.constraint_type='R'
  and b.constraint_type='P'
  and a.r_owner=b.owner
  and a.constraint_name=c.constraint_name
  and b.constraint_name=d.constraint_name
  and a.owner=c.owner
  and a.table_name=c.table_name
  and b.owner=d.owner
  and b.table_name=d.table_name
  /

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/14864453/viewspace-416222/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/14864453/viewspace-416222/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值