美文网首页
Oracle PL/SQL(2) - 查询某表的约束条件

Oracle PL/SQL(2) - 查询某表的约束条件

作者: 乘风破浪的姐姐 | 来源:发表于2020-03-20 17:42 被阅读0次

Oracle将用户创建的表、约束等信息都放在数据字典表中,允许开发人员查询数据字典表或视图来获取数据库对象的信息。

如下数据字典视图提供了约束的详细信息:

  • user_constraints:如果知道约束名,想知道约束类型,可以查询user_constraints,这个视图描述了约束的定义,但是它不描述约束定义在哪些字段名称上。
  • user_cons_columns:视图中显示约束的字段名称。如果主键是一个联合主键,这个视图中将有这个约束的两条记录,联合主键的每一个字段对应一条记录。每一条记录通过position(在联合主键中的位置)来区别。

例如:使用user_constraints查询t_claim表中的所有约束

SELECT constraint_name, search_condition, status
  FROM user_constraints
 WHERE table_name = UPPER ('t_claim');

查询结果:


image.png

例如:使用user_cons_columns查询t_claim表约束应用的列信息

SELECT constraint_name, column_name
  FROM user_cons_columns
 WHERE table_name = UPPER ('t_claim');

查询结果:


image.png

查询表的主键

select cu.* from user_cons_columns cu, user_constraints au 
where cu.constraint_name = au.constraint_name 
and au.constraint_type = 'P' AND cu.table_name = UPPER ('t_claim')

查询结果:


image.png

查找表的外键

select * from user_constraints c where c.constraint_type = 'R' and c.table_name = UPPER ('t_claim')

查询结果:


image.png

查询外键约束的列名:

select * from user_cons_columns cl where cl.constraint_name = 'PK_ACCIDENT'

查询结果:


image.png

查询表的所有列及其属性

select t.*,c.COMMENTS from user_tab_columns t,user_col_comments c where  c.table_name = UPPER ('t_claim')

查询结果:


image.png

例如:使用all_constraints和all_cons_columns来获取t_claim表 约束的详细信息

 SELECT a.table_name, 
       a.constraint_name, 
       a.search_condition, 
       b.column_name,
       a.constraint_type
  FROM all_constraints a, all_cons_columns b
 WHERE a.table_name = UPPER ('t_claim')
   AND a.table_name = b.table_name
   AND a.owner = b.owner
   AND a.constraint_name = b.constraint_name;

查询结果:


image.png

相关文章

网友评论

      本文标题:Oracle PL/SQL(2) - 查询某表的约束条件

      本文链接:https://www.haomeiwen.com/subject/rizjyhtx.html