在Oracle中查看全部的表: 索引
select * from tab/dba_tables/dba_objects/cat; table
看用户创建的表 : object
select table_name from user_tables; //当前用户的表 select
select table_name from all_tables; //全部用户的表 引用
select table_name from dba_tables; //包括系统表 查询
select * from user_indexes //能够查询出全部的用户表索引 db
查全部用户的表在all_tables tab
主键名称、外键在all_constraints view
索引在all_indexes vi
但主键也会成为索引,因此主键也会在all_indexes里面。
具体须要的字段能够DESC下这几个view,dba登录的话能够把all换成dba
一、查找表的全部索引(包括索引名,类型,构成列):
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 = 要查询的表
二、查找表的主键(包括名称,构成列):
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 = 要查询的表
三、查找表的惟一性约束(包括名称,构成列):
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 = 要查询的表
四、查找表的外键(包括名称,引用表的表名和对应的键名,下面是分红多步查询):
select * from user_constraints c where c.constraint_type = 'R' and c.table_name = 要查询的表
查询外键约束的列名:
select * from user_cons_columns cl where cl.constraint_name = 外键名称
查询引用表的键的列名:
select * from user_cons_columns cl where cl.constraint_name = 外键引用表的键名
五、查询表的全部列及其属性
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 = 要查询的表