首頁  >  文章  >  資料庫  >  聯合主鍵和複合主鍵的區別

聯合主鍵和複合主鍵的區別

王林
王林轉載
2019-08-28 14:22:459238瀏覽

一、複合主鍵

所謂的複合主鍵就是指你表的主鍵含有一個以上的欄位組成,不使用無業務意義的自增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,怎麼辦呢,學生的名字、年齡、班級都可能重複,無法使用單個字段來唯一標識,這時,我們可以將多個字段設置為主鍵,形成複合主鍵,這多個字段聯合標識唯一性,其中,某幾個主鍵字段值出現重複是沒有問題的,只要不是有多條記錄的所有主鍵值完全一樣,就不算重複。

二、聯合主鍵

合併主鍵顧名思義就是多個主鍵結合形成一個主鍵組合(主鍵原則上是唯一的,別被唯一值所困擾。)  

聯合主鍵的意義:用2個字段(或者多個字段,後面具體都是用2個字段組合)來確定一條記錄,說明,這2個欄位都不是唯一的,2個欄位可以分別重複,這麼設定的好處,可以很直覺的看到某個重複欄位的記錄條數。

一個簡單的例子:

主鍵A跟主鍵B組成聯合主鍵 

主鍵A跟主鍵B的資料可以完全相同,聯合在於主鍵A跟主鍵B形成的聯合主鍵是唯一的。 
下例主鍵A資料是1,主鍵B資料也是1,聯合主鍵其實是11,這個11是唯一值,絕對不充實再出現11這個唯一值。 (這就是多對多關係) 

主鍵A資料主鍵B資料 
1      1 
2      2 #3      2 #3      2 #3      數值最多也就是

11 

12 

13 

21 
22 
23 
31 
#32 
#33

摘要總結: 以我來看複合主鍵就是含有一個以上的字段組成,如ID name,ID phone等,而聯合主鍵要同時是兩個表的主題組合起來的。這是和複合主鍵最大的區別!

相了解更多相關問題請訪問PHP中文網:

mysql視頻教程

#

以上是聯合主鍵和複合主鍵的區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除