約束清理

查詢出所有的用戶表。
查所有用戶的表在all_tables
主鍵名稱、外鍵在all_constraints
索引在all_indexes
但主鍵也會成爲索引,所以主鍵也會在all_indexes裏面。
具體需要的字段可以DESC下這幾個view,dba登陸的話可以把all換成dba。
查詢用戶表的索引(非聚集索引):
select  *  from  user_indexes where  uniqueness  =  'NONUNIQUE'


select ' drop index ' || index_name || ';'from  user_indexes where  uniqueness  =  'NONUNIQUE'
查詢用戶表的主鍵(聚集索引):
select  *  from  user_indexes where  uniqueness  =  'UNIQUE'


select ' alter table ' || table_name || ' drop constraint ' || index_name|| ';'from  user_indexes where  uniqueness  =  'NONUNIQUE'
1、查找表的所有索引(包括索引名,類型,構成列):
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
select 'drop index ' || t.index_name ||  ';' from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name
2、查找表的主鍵(包括名稱,構成列):
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 ' alter table ' || t.table_name || ' drop constraint ' || t.index_name|| ';' from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name
3、查找表的唯一性約束(包括名稱,構成列):
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 = 要查詢的表
4、查找表的外鍵(包括名稱,引用表的表名和對應的鍵名,下面是分成多步查詢):
select * from user_constraints c where c.constraint_type = 'R' and c.table_name = 要查詢的表
查詢外鍵約束的列名:
select * from user_cons_columns cl where cl.constraint_name = 外鍵名稱
查詢引用表的鍵的列名:
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章