初探SQL語(yǔ)句復(fù)合主鍵與聯(lián)合主鍵
一、復(fù)合主鍵
所謂的復(fù)合主鍵 就是指你表的主鍵含有一個(gè)以上的字段組成,不使用無(wú)業(yè)務(wù)含義的自增id作為主鍵。
比如
create table test ( name varchar(19), id number, value varchar(10), primary key (name,id) )
上面的name和id字段組合起來(lái)就是你test表的復(fù)合主鍵 ,它的出現(xiàn)是因?yàn)槟愕膎ame字段可能會(huì)出現(xiàn)重名,所以要加上ID字段這樣就可以保證你記錄的唯一性 ,一般情況下,主鍵的字段長(zhǎng)度和字段數(shù)目要越少越好 。
這里就會(huì)有一個(gè)疑惑? 主鍵是唯一的索引,那么為何一個(gè)表可以創(chuàng)建多個(gè)主鍵呢?
其實(shí)“主鍵是唯一的索引”這話(huà)有點(diǎn)歧義的。舉個(gè)例子,我們?cè)诒碇袆?chuàng)建了一個(gè)ID字段,自動(dòng)增長(zhǎng),并設(shè)為主鍵,這個(gè)是沒(méi)有問(wèn)題的,因?yàn)椤爸麈I是唯一的索引”,ID自動(dòng)增長(zhǎng)保證了唯一性,所以可以。
此時(shí),我們?cè)賱?chuàng)建一個(gè)字段name,類(lèi)型為varchar,也設(shè)置為主鍵,你會(huì)發(fā)現(xiàn),在表的多行中你是可以填寫(xiě)相同的name值的,這豈不是有違“主鍵是唯一的索引”這句話(huà)么?
所以我才說(shuō)“主鍵是唯一的索引”是有歧義的。應(yīng)該是“當(dāng)表中只有一個(gè)主鍵時(shí),它是唯一的索引;當(dāng)表中有多個(gè)主鍵時(shí),稱(chēng)為復(fù)合主鍵,復(fù)合主鍵聯(lián)合保證唯一索引”。
為什么自增長(zhǎng)ID已經(jīng)可以作為唯一標(biāo)識(shí)的主鍵,為啥還需要復(fù)合主鍵呢。因?yàn)?,并不是所有的表都要有ID這個(gè)字段,比如,我們建一個(gè)學(xué)生表,沒(méi)有唯一能標(biāo)識(shí)學(xué)生的ID,怎么辦呢,學(xué)生的名字、年齡、班級(jí)都可能重復(fù),無(wú)法使用單個(gè)字段來(lái)唯一標(biāo)識(shí),這時(shí),我們可以將多個(gè)字段設(shè)置為主鍵,形成復(fù)合主鍵,這多個(gè)字段聯(lián)合標(biāo)識(shí)唯一性,其中,某幾個(gè)主鍵字段值出現(xiàn)重復(fù)是沒(méi)有問(wèn)題的,只要不是有多條記錄的所有主鍵值完全一樣,就不算重復(fù)。
二、聯(lián)合主鍵
聯(lián)合主鍵顧名思義就是多個(gè)主鍵聯(lián)合形成一個(gè)主鍵組合(主鍵原則上是唯一的,別被唯一值所困擾。)
聯(lián)合主鍵的意義:用2個(gè)字段(或者多個(gè)字段,后面具體都是用2個(gè)字段組合)來(lái)確定一條記錄,說(shuō)明,這2個(gè)字段都不是唯一的,2個(gè)字段可以分別重復(fù),這么設(shè)置的好處,可以很直觀(guān)的看到某個(gè)重復(fù)字段的記錄條數(shù)。
一個(gè)簡(jiǎn)單的例子
主鍵A跟主鍵B組成聯(lián)合主鍵
主鍵A跟主鍵B的數(shù)據(jù)可以完全相同,聯(lián)合就在于主鍵A跟主鍵B形成的聯(lián)合主鍵是唯一的。
下例主鍵A數(shù)據(jù)是1,主鍵B數(shù)據(jù)也是1,聯(lián)合主鍵其實(shí)是11,這個(gè)11是唯一值,絕對(duì)不充許再出現(xiàn)11這個(gè)唯一值。(這就是多對(duì)多關(guān)系)
主鍵A數(shù)據(jù) 主鍵B數(shù)據(jù)
1 1
2 2
3 3
主鍵A與主鍵B的聯(lián)合主鍵值最多也就是
11
12
13
21
22
23
31
32
33
總結(jié): 以我來(lái)看復(fù)合主鍵就是含有一個(gè)以上的字段組成,如ID+name,ID+phone等,而聯(lián)合主鍵要同時(shí)是兩個(gè)表的主題組合起來(lái)的。這是和復(fù)合主鍵最大的區(qū)別!
以上就是本文關(guān)于初探SQL語(yǔ)句復(fù)合主鍵與聯(lián)合主鍵的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以參閱:幾個(gè)比較重要的MySQL變量、MySQL prepare原理詳解、MySQL刪除有外鍵約束的表數(shù)據(jù)方法介紹等,有什么問(wèn)題可以隨時(shí)留言,大家一起討論,共同進(jìn)步。
相關(guān)文章
MySQL創(chuàng)建用戶(hù)與授權(quán)方法
MySQL中創(chuàng)建用戶(hù)與授權(quán)的實(shí)現(xiàn)方法,對(duì)于剛開(kāi)始接觸mysql的朋友可以參考下2012-11-11詳解MySQL開(kāi)啟遠(yuǎn)程連接權(quán)限
這篇文章主要介紹了MySQL開(kāi)啟遠(yuǎn)程連接權(quán)限,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04MySQL數(shù)據(jù)庫(kù)的事務(wù)和索引詳解
這篇文章主要介紹了MySql 索引和事務(wù),總結(jié)分析了mysql數(shù)據(jù)庫(kù)中關(guān)于索引和事務(wù)的概念、原理、知識(shí)點(diǎn)及相關(guān)注意事項(xiàng),需要的朋友可以參考下2021-10-10MySql創(chuàng)建帶解釋的表及給表和字段加注釋的實(shí)現(xiàn)代碼
這篇文章主要介紹了MySql創(chuàng)建帶解釋的表以及給表和字段加注釋的實(shí)現(xiàn)方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12Mysq詳細(xì)講解如何解決庫(kù)存并發(fā)問(wèn)題
這篇文章主要為大家詳細(xì)介紹了如何使用Mysq解決庫(kù)存并發(fā)問(wèn)題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05