欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2017年10月10日 16:48:15   作者:lfendo  
這篇文章主要介紹了初探SQL語句復(fù)合主鍵與聯(lián)合主鍵的相關(guān)內(nèi)容,具有一定參考價值,這里給大家分享下,需要的朋友可以參考。

一、復(fù)合主鍵

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

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

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

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

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

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

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

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

二、聯(lián)合主鍵

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

           聯(lián)合主鍵的意義:用2個字段(或者多個字段,后面具體都是用2個字段組合)來確定一條記錄,說明,這2個字段都不是唯一的,2個字段可以分別重復(fù),這么設(shè)置的好處,可以很直觀的看到某個重復(fù)字段的記錄條數(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這個唯一值。(這就是多對多關(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é): 以我來看復(fù)合主鍵就是含有一個以上的字段組成,如ID+name,ID+phone等,而聯(lián)合主鍵要同時是兩個表的主題組合起來的。這是和復(fù)合主鍵最大的區(qū)別!

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

相關(guān)文章

  • mysql 8.0.16 winx64安裝配置方法圖文教程

    mysql 8.0.16 winx64安裝配置方法圖文教程

    這篇文章主要為大家分享了mysql 8.0.16 安裝配置方法圖文教程,具有一定的參考價值,感興趣的朋友可以參考一下
    2019-05-05
  • MySQL創(chuàng)建用戶與授權(quán)方法

    MySQL創(chuàng)建用戶與授權(quán)方法

    MySQL中創(chuàng)建用戶與授權(quán)的實現(xiàn)方法,對于剛開始接觸mysql的朋友可以參考下
    2012-11-11
  • MySQL雙主(主主)架構(gòu)配置方案

    MySQL雙主(主主)架構(gòu)配置方案

    這篇文章主要介紹了MySQL雙主(主主)架構(gòu)配置方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 詳解MySQL開啟遠程連接權(quán)限

    詳解MySQL開啟遠程連接權(quán)限

    這篇文章主要介紹了MySQL開啟遠程連接權(quán)限,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • MySQL數(shù)據(jù)庫的事務(wù)和索引詳解

    MySQL數(shù)據(jù)庫的事務(wù)和索引詳解

    這篇文章主要介紹了MySql 索引和事務(wù),總結(jié)分析了mysql數(shù)據(jù)庫中關(guān)于索引和事務(wù)的概念、原理、知識點及相關(guān)注意事項,需要的朋友可以參考下
    2021-10-10
  • MySql中怎樣查詢表是否被鎖

    MySql中怎樣查詢表是否被鎖

    這篇文章主要介紹了MySql中怎樣查詢表是否被鎖問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • mysql found_row()使用詳解

    mysql found_row()使用詳解

    在參考手冊中對found_rows函數(shù)的描述是: it is desirable to know how many rows the statement would have returned without the LIMIT. 也就是說,它返回值是如果SQL語句沒有加LIMIT的情況下返回的數(shù)值。
    2016-05-05
  • MySql創(chuàng)建帶解釋的表及給表和字段加注釋的實現(xiàn)代碼

    MySql創(chuàng)建帶解釋的表及給表和字段加注釋的實現(xiàn)代碼

    這篇文章主要介紹了MySql創(chuàng)建帶解釋的表以及給表和字段加注釋的實現(xiàn)方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12
  • 詳細解讀MySQL的觸發(fā)器trigger

    詳細解讀MySQL的觸發(fā)器trigger

    觸發(fā)器是由事件來觸發(fā)某個操作,這些事件包括INSERT、UPDATE和DELETE語句。如果定義了觸發(fā)程序,當(dāng)數(shù)據(jù)庫執(zhí)行這些語句的時候就會激發(fā)觸發(fā)器執(zhí)行相應(yīng)的操作,需要的朋友可以參考下
    2023-05-05
  • Mysq詳細講解如何解決庫存并發(fā)問題

    Mysq詳細講解如何解決庫存并發(fā)問題

    這篇文章主要為大家詳細介紹了如何使用Mysq解決庫存并發(fā)問題,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05

最新評論