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

MySQL中關(guān)于超鍵和主鍵及候選鍵的區(qū)別

 更新時間:2022年07月31日 14:53:26   作者:胖了個頭  
這篇文章主要介紹了MySQL中關(guān)于超鍵和主鍵及候選鍵的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

關(guān)于超鍵和主鍵及候選鍵的區(qū)別

最近在看MySQL的書時遇到了一個問題:

既然已經(jīng)有了主鍵這個概念,主鍵已經(jīng)能夠滿足需求了,那為什么還要有候選鍵這種東西?候選鍵的作用是什么呢?給了它一個候選鍵的定義但是它真的并沒有什么亂用。

抱著刨根問底攔不住的心態(tài)我去網(wǎng)上搜了搜,看了看大神們的解釋,看得我還是有些懵懂,于是想在這里梳理一下,幫助自己理解的更通透,也希望如果有理解錯的地方能有人指點一下 下面就是我的一些理解:

其實主鍵和超鍵還好一些,比如有這么一個表:

在這里插入圖片描述

表寫的有些糙,湊合看吧。

超鍵

在關(guān)系中能唯一標(biāo)識元組的屬性集稱為關(guān)系模式的超鍵。 注定義中的“屬性集”,超鍵可以是一個很大的集合,只要他能確定是哪一行就行,因此’id’,‘user’,‘pwd’,‘section’,'name’都可以是超鍵的集。

候選鍵

不含有多余屬性的超鍵,比如在上面的超鍵中,'id’自己就可以獨自確定是哪一行,所以他自己可以是一個候選鍵,除去它以外的另外四個也可以是候選鍵,但是這五個放在一起因為有了多余的列,他們就不是候選鍵。(另外四個可以是候選鍵的原因是每一列都有可能有重復(fù)的內(nèi)容)

主鍵

在所有的候選鍵里面找一個作為主鍵供使用,也就是說可以是id,也可以是另外四個的合體,也有可能是其他的選擇,只要能保證選擇的集合能唯一確定即可。

總結(jié)來說,候選鍵是超鍵的子集,主鍵是候選鍵的子集。

其實整理了這么多以后我還是不明白候選鍵的作用到底是什么,其實他可能就是作為一個候車廳一樣,車上只剩下一個座位,有幾個主鍵在候車廳里坐著,告訴你:“我們幾個人都買票了,都有資格上車,你選誰上,我們誰就跟你去上車”,應(yīng)該就是這樣。

理解超鍵、候選鍵、主鍵概念及關(guān)系

基本概念

  • 超鍵(super key):在關(guān)系中能唯一標(biāo)識元組的屬性集稱為關(guān)系模式的超鍵/碼。
  • 候選鍵(candidate key):不含有多余屬性的超鍵稱為候選鍵,即其真子集不再是超鍵。
  • 主鍵(primary key):用戶選作元組標(biāo)識的一個候選鍵稱為主鍵,是候選鍵之一。

關(guān)系

候選鍵是超鍵的子集,主鍵是候選鍵中的一個。

舉個栗子

考慮屬性集(身份證號,姓名 ,性別 ,年齡),假設(shè)無重名

a.其中超鍵有:

  • 身份證號、姓名、(姓名,性別)、(姓名,性別,年齡)等
  • --這里可以看出,超鍵是能唯一確定一個人的屬性組

b.超鍵中的候選鍵

  • 身份證號、姓名唯一,而且沒有多余屬性,所以是一個候選鍵
  • --這里可以看出,候選鍵是沒有多余屬性的超鍵

c.選擇主鍵

  • 用戶可根據(jù)自己喜好考慮選擇姓名或者身份證號作為主鍵
  • --主鍵是選中的一個候選鍵

還不明白?

實例:

在SQL Server數(shù)據(jù)庫中,有一個學(xué)生信息表如下所示,在該表中不能作為候選鍵的屬性集合為( ) (選擇一項)

學(xué)號 姓名 性別 年齡 系別 專業(yè)
20020612 李輝 男 20 計算機 軟件開發(fā)
20060613 張明 男 18 計算機 軟件開發(fā)
20060614 王小玉 女 19 物理 力學(xué)
20060615 李淑華 女 17 生物 動物學(xué)
20060616 趙靜 男 21 化學(xué) 食品化學(xué)
20060617 趙靜 女 20 生物 植物學(xué)

a){學(xué)號}
b){學(xué)號、姓名}
c){年齡、系別}
d){姓名、性別}
e){姓名、專業(yè)}

如果大家還不知道如何來選擇,再看看基本概念吧!

嗯,不會的就選C吧,哈哈哈哈哈哈

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于MySQL 大批量插入時如何過濾掉重復(fù)數(shù)據(jù)

    關(guān)于MySQL 大批量插入時如何過濾掉重復(fù)數(shù)據(jù)

    這篇文章主要介紹關(guān)于MySQL 大批量插入時如何過濾重復(fù)數(shù)據(jù),比如線上庫有6個表存在重復(fù)數(shù)據(jù),其中2個表比較大,96萬+和30萬+,因為之前處理過相同的問題,就直接拿來了上次的Python去重腳本,腳本很簡單,就是連接數(shù)據(jù)庫,查出來重復(fù)數(shù)據(jù),循環(huán)刪除,需要的朋友可以參考下
    2021-09-09
  • Mysql查詢語句詳細(xì)總結(jié)大全

    Mysql查詢語句詳細(xì)總結(jié)大全

    這篇文章主要給大家介紹了關(guān)于Mysql查詢語句詳細(xì)總結(jié)的相關(guān)資料,MySQL是一種關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它支持SQL語言進(jìn)行數(shù)據(jù)查詢,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • MySQL一個語句查出各種整形占用字節(jié)數(shù)及最大最小值的實例

    MySQL一個語句查出各種整形占用字節(jié)數(shù)及最大最小值的實例

    下面小編就為大家?guī)硪黄狹ySQL一個語句查出各種整形占用字節(jié)數(shù)及最大最小值的實例。
    2017-03-03
  • Win10 64位使用壓縮包安裝最新MySQL8.0.18的教程(圖文詳解)

    Win10 64位使用壓縮包安裝最新MySQL8.0.18的教程(圖文詳解)

    本文通過圖文并茂的形式給大家介紹了WIN10 64位使用壓縮包安裝最新MySQL8.0.18的教程,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • Python MySQL進(jìn)行數(shù)據(jù)庫表變更和查詢

    Python MySQL進(jìn)行數(shù)據(jù)庫表變更和查詢

    這篇文章主要介紹了Python MySQL進(jìn)行數(shù)據(jù)庫表變更和查詢的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • MYSQL 5.6 從庫復(fù)制的部署和監(jiān)控的實現(xiàn)

    MYSQL 5.6 從庫復(fù)制的部署和監(jiān)控的實現(xiàn)

    這篇文章主要介紹了MYSQL 5.6 從庫復(fù)制的部署和監(jiān)控的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • MySQL高級特性——數(shù)據(jù)表分區(qū)的概念及機制詳解

    MySQL高級特性——數(shù)據(jù)表分區(qū)的概念及機制詳解

    當(dāng)數(shù)據(jù)表過大時,通過普通的查詢優(yōu)化技巧已經(jīng)無法大幅度提升性能,此時往往需要進(jìn)行分區(qū)分表優(yōu)化。分區(qū)其實是將一張邏輯上統(tǒng)一的表在物理上劃分成了多張表。分區(qū)操作對使用者而言是一個黑盒操作,但是如果你從文件系統(tǒng)上看,就會看到分區(qū)數(shù)據(jù)表的實際存儲方式是分開的。
    2021-05-05
  • mysql踩坑之count distinct多列問題

    mysql踩坑之count distinct多列問題

    這篇文章主要介紹了mysql踩坑之count distinct多列問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • MySQL條件查詢語句常用操作全面匯總

    MySQL條件查詢語句常用操作全面匯總

    當(dāng)用戶查看表格的大量數(shù)據(jù)是,由于數(shù)據(jù)量過于巨大會導(dǎo)致很難獲取到需要的數(shù)據(jù),在這時,就需要一個方法,一個可以通過用戶輸入獲取到用戶需要的數(shù)據(jù)并回填入表格,這就是條件查詢的作用
    2022-04-04
  • MAC系統(tǒng)中添加MYSQL開機啟動的方法

    MAC系統(tǒng)中添加MYSQL開機啟動的方法

    這篇文章主要介紹了MAC系統(tǒng)中添加MYSQL開機啟動的方法,本文簡潔易懂,步驟清晰,需要的朋友可以參考下
    2014-11-11

最新評論