天天看點

oracle 唯一索引,唯一限制,主鍵之間的聯系

主鍵(primary key)是表中的一個或多個字段,它的值用于唯一地辨別表中的某一條記錄,在兩個表的關系中,主鍵用來在一個表中引用來自于另一個表中的特定記錄,,主鍵時一種唯一關鍵字,表定義的一部分。一個表的主鍵可以由多個關鍵字共同組成,并且主鍵不能包含空值。oracle中建立主鍵後會自動生成一個唯一索引,并且該唯一索引可以在user_indexes視圖中查到。

建立兩張表結構相同的表,test_1指定c1為主鍵,test_2給c1添加NOT NULL 和UNIQUE限制,不指定主鍵。

oracle 唯一索引,唯一限制,主鍵之間的聯系

檢視test_1,test_2的索引

oracle 唯一索引,唯一限制,主鍵之間的聯系

檢視test_1,test_2的限制

oracle 唯一索引,唯一限制,主鍵之間的聯系

唯一索引,不允許具有索引值相同的行,進而禁止重複的索引或鍵值。系統在建立該索引時檢查是否有重複的鍵值,并在每次使用 INSERT 或 UPDATE 語句添加資料時進行檢查。

建立test_5表,為c1添加唯一索引。

oracle 唯一索引,唯一限制,主鍵之間的聯系

檢視test_5上的索引。

oracle 唯一索引,唯一限制,主鍵之間的聯系

檢視test_5上的限制。

oracle 唯一索引,唯一限制,主鍵之間的聯系

唯一限制保證在一個字段或者一組字段裡的資料與表中其它行的資料相比是唯一的。在oracle中建立了唯一限制,會相應生成一個唯一索引。

建立表test_6,給c1列添加唯一限制。

oracle 唯一索引,唯一限制,主鍵之間的聯系

檢視test_6上的限制。

oracle 唯一索引,唯一限制,主鍵之間的聯系

檢視test_6上的索引。

oracle 唯一索引,唯一限制,主鍵之間的聯系

本文轉自 天黑順路 51CTO部落格,原文連結:http://blog.51cto.com/mjal01/2066731,如需轉載請自行聯系原作者