• Oracle数据库查询唯一约束、索引


    一、查找表的所有索引(包括索引名,类型,构成列)

    select t.*,i.index_type from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name and t.table_name = 要查询的表
    
    • 1

    在这里插入图片描述

    二、查找表的主键(包括名称,构成列)

    select cu.* from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'P' and au.table_name = 要查询的表
    
    • 1

    在这里插入图片描述

    三、查找表的唯一性约束(包括名称,构成列)

    select column_name from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'U' and au.table_name = 要查询的表
    
    • 1

    在这里插入图片描述

    四、查找表的外键(包括名称,引用表的表名和对应的键名,下面是分成多步查询)

    select * from user_constraints c where c.constraint_type = 'R' and c.table_name = 要查询的表
    
    • 1

    在这里插入图片描述

    查询外键约束的列名:

    select * from user_cons_columns cl where cl.constraint_name = 外键名称
    
    • 1

    在这里插入图片描述

    查询引用表的键的列名:

    select * from user_cons_columns cl where cl.constraint_name = 外键引用表的键名
    
    • 1

    五、查询表的所有列及其属性

    select t.*,c.COMMENTS from user_tab_columns t,user_col_comments c where t.table_name = c.table_name and t.column_name = c.column_name and t.table_name = 要查询的表
    
    • 1

    在这里插入图片描述

    六、总结

    查询Oracle表的信息(表,字段,约束,索引)

    1、查询出所有的用户表
    select * from user_tables 可以查询出所有的用户表

    2、查询出用户所有表的索引
    select * from user_indexes

    3、查询用户表的索引(非聚集索引):
    select * from user_indexes where uniqueness=‘NONUNIQUE’

    4、查询用户表的主键(聚集索引):
    select * from user_indexes where uniqueness=‘UNIQUE’

    5、查询表的索引
    select t.*,i.index_type from user_ind_columns t,user_indexes i where t.index_name = i.index_name and
    t.table_name=‘NODE’

    6、查询表的主键
    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 = ‘NODE’

    7、查找表的唯一性约束(包括名称,构成列):
    select column_name from user_cons_columns cu, user_constraints au where cu.constraint_name=au.constraint_name and
    cu.table_name=‘NODE’

    8、查找表的外键
    select * from user_constraints c where c.constraint_type = ‘R’ and c.table_name=‘STAFFPOSITION’

    查询外键约束的列名:
    select * from user_cons_columns cl where cl.constraint_name = 外键名称

    查询引用表的键的列名:
    select * from user_cons_columns cl where cl.constraint_name = 外键引用表的键名

    9、查询表的所有列及其属性
    select t.*,c.COMMENTS from user_tab_columns t,user_col_comments c where t.table_name=‘NODE’

  • 相关阅读:
    面试:聊一聊 Java 数组默认的排序算法,我懵了
    B+树索引(6)之MyISAM索引方案
    国内新闻媒体排行,如何邀约媒体现场造势?
    Apache PLC4X 副总裁宣布个人停止对项目提供免费支持;Linux 5.17 增加对中国 Soc 的支持;IPython 8.0 发布 | 开源日报
    【软件测试】一位优秀测试工程师具备哪些知识和经验?
    持续集成指南:GitHubAction 自动构建+部署AspNetCore项目
    信息科学与技术导论
    SpringBoot基础篇学习笔记
    深度学习入门(十九)深度学习计算——自定义层
    1991年至2008年澳大利亚每月的抗糖尿病药物补贴时间序列分析
  • 原文地址:https://blog.csdn.net/KevinChen2019/article/details/128167531