所謂的復合主鍵 就是指你表的主鍵含有一個以上的字段組成,不使用無業務含義的自增id作為主鍵。
比如?
create?table?test? (? ???name?varchar(19),? ???id?number,? ???value?varchar(10),? ???primary?key?(name,id)? )
上面的name和id字段組合起來就是你test表的復合主鍵 ,它的出現是因為你的name字段可能會出現重名,所以要加上ID字段這樣就可以保證你記錄的唯一性 ,一般情況下,主鍵的字段長度和字段數目要越少越好 。
這里就會有一個疑惑?? 主鍵是唯一的索引,那么為何一個表可以創建多個主鍵呢?
其實“主鍵是唯一的索引”這話有點歧義的。舉個例子,我們在表中創建了一個ID字段,自動增長,并設為主鍵,這個是沒有問題的,因為“主鍵是唯一的索引”,ID自動增長保證了唯一性,所以可以。
此時,我們再創建一個字段name,類型為varchar,也設置為主鍵,你會發現,在表的多行中你是可以填寫相同的name值的,這豈不是有違“主鍵是唯一的索引”這句話么?
所以我才說“主鍵是唯一的索引”是有歧義的。應該是“當表中只有一個主鍵時,它是唯一的索引;當表中有多個主鍵時,稱為復合主鍵,復合主鍵聯合保證唯一索引”。
為什么自增長ID已經可以作為唯一標識的主鍵,為啥還需要復合主鍵呢。因為,并不是所有的表都要有ID這個字段,比如,我們建一個學生表,沒有唯一能標識學生的ID,怎么辦呢,學生的名字、年齡、班級都可能重復,無法使用單個字段來唯一標識,這時,我們可以將多個字段設置為主鍵,形成復合主鍵,這多個字段聯合標識唯一性,其中,某幾個主鍵字段值出現重復是沒有問題的,只要不是有多條記錄的所有主鍵值完全一樣,就不算重復。
怎么把復合主鍵改為單一主鍵
一個表只能有一個主鍵:?
基于一列的主鍵:
alter table test add constraint PK_TEST primary key(ename);
基于多列的聯合主鍵:?
alter table test add constraint PK_TEST primary key(ename,birthday);