主鍵約束,唯一性約束,唯一性索引

1)主鍵列:比如我們在表A中指定ID爲主鍵,Oracle數據庫會自動創建一個同名的唯一索引
可以通過 select constraint_name,constraint_type from user_indexes ui where ui.table_name='A'來查看主鍵上的唯一索引,如果此時我們在給ID列去創建唯一性索引或者非唯一性索引的話,都會報錯,當然指定主鍵之後自動也會生成主鍵約束,主鍵就是一種約束
(2)非主鍵列:我們在非主鍵列上創建一個唯一性約束,Oracle同樣自動創建了一個同名的唯一索引,而且也不允許再在此列上創建唯一索引或非唯一索引,雖然主鍵約束要求列值非空(NOT NULL),但是創建唯一鍵約束和唯一性索引的列值卻可以爲空。
所以一個表可以有多個唯一索引的.

Oracle:查找表的主鍵,外鍵,唯一性約束,索引 
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 and t.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 = 要查詢的表
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 = 外鍵名稱
查詢引用表的鍵的列名:
select * from user_cons_columns cl where cl.constraint_name = 外鍵引用表的鍵名
5、查詢表的所有列及其屬性
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 = 要查詢的表

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章