主頁 > 知識庫 > 初探SQL語句復合主鍵與聯(lián)合主鍵

初探SQL語句復合主鍵與聯(lián)合主鍵

熱門標簽:怎么申請400電話申請 龍圖酒吧地圖標注 怎么辦理400電話呢 電話機器人免費嗎 地圖標注圖標素材入駐 400電話申請什么好 電銷機器人價格多少錢一臺 好搜地圖標注 百度地圖標注地方備注

一、復合主鍵

  所謂的復合主鍵 就是指你表的主鍵含有一個以上的字段組成,不使用無業(yè)務含義的自增id作為主鍵。
比如

create table test  
(  
  name varchar(19),  
  id number,  
  value varchar(10),  
  primary key (name,id)  
)

   上面的name和id字段組合起來就是你test表的復合主鍵 ,它的出現(xiàn)是因為你的name字段可能會出現(xiàn)重名,所以要加上ID字段這樣就可以保證你記錄的唯一性 ,一般情況下,主鍵的字段長度和字段數(shù)目要越少越好 。

這里就會有一個疑惑?  主鍵是唯一的索引,那么為何一個表可以創(chuàng)建多個主鍵呢?

其實“主鍵是唯一的索引”這話有點歧義的。舉個例子,我們在表中創(chuàng)建了一個ID字段,自動增長,并設為主鍵,這個是沒有問題的,因為“主鍵是唯一的索引”,ID自動增長保證了唯一性,所以可以。

此時,我們再創(chuàng)建一個字段name,類型為varchar,也設置為主鍵,你會發(fā)現(xiàn),在表的多行中你是可以填寫相同的name值的,這豈不是有違“主鍵是唯一的索引”這句話么?

所以我才說“主鍵是唯一的索引”是有歧義的。應該是“當表中只有一個主鍵時,它是唯一的索引;當表中有多個主鍵時,稱為復合主鍵,復合主鍵聯(lián)合保證唯一索引”。

為什么自增長ID已經(jīng)可以作為唯一標識的主鍵,為啥還需要復合主鍵呢。因為,并不是所有的表都要有ID這個字段,比如,我們建一個學生表,沒有唯一能標識學生的ID,怎么辦呢,學生的名字、年齡、班級都可能重復,無法使用單個字段來唯一標識,這時,我們可以將多個字段設置為主鍵,形成復合主鍵,這多個字段聯(lián)合標識唯一性,其中,某幾個主鍵字段值出現(xiàn)重復是沒有問題的,只要不是有多條記錄的所有主鍵值完全一樣,就不算重復。

二、聯(lián)合主鍵

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

           聯(lián)合主鍵的意義:用2個字段(或者多個字段,后面具體都是用2個字段組合)來確定一條記錄,說明,這2個字段都不是唯一的,2個字段可以分別重復,這么設置的好處,可以很直觀的看到某個重復字段的記錄條數(shù)。

一個簡單的例子

主鍵A跟主鍵B組成聯(lián)合主鍵

主鍵A跟主鍵B的數(shù)據(jù)可以完全相同,聯(lián)合就在于主鍵A跟主鍵B形成的聯(lián)合主鍵是唯一的。

下例主鍵A數(shù)據(jù)是1,主鍵B數(shù)據(jù)也是1,聯(lián)合主鍵其實是11,這個11是唯一值,絕對不充許再出現(xiàn)11這個唯一值。(這就是多對多關系)

主鍵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

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

以上就是本文關于初探SQL語句復合主鍵與聯(lián)合主鍵的全部內容,希望對大家有所幫助。感興趣的朋友可以參閱:幾個比較重要的MySQL變量、MySQL prepare原理詳解、MySQL刪除有外鍵約束的表數(shù)據(jù)方法介紹等,有什么問題可以隨時留言,大家一起討論,共同進步。

您可能感興趣的文章:
  • sql中設置聯(lián)合主鍵的具體方法
  • sql server創(chuàng)建復合主鍵的2種方法
  • MySQL 創(chuàng)建主鍵,外鍵和復合主鍵的語句

標簽:廣西 防疫工作 固原 浙江 溫州 汕尾 內江 撫順

巨人網(wǎng)絡通訊聲明:本文標題《初探SQL語句復合主鍵與聯(lián)合主鍵》,本文關鍵詞  初探,SQL,語句,復合,主鍵,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《初探SQL語句復合主鍵與聯(lián)合主鍵》相關的同類信息!
  • 本頁收集關于初探SQL語句復合主鍵與聯(lián)合主鍵的相關信息資訊供網(wǎng)民參考!
  • 推薦文章