菜鳥學資料庫(四)——超鍵、候選鍵、主鍵、外來鍵

劉水鏡發表於2013-10-17

這些年的一些經歷告訴我,很多初學者搞不清超鍵、候選鍵等,被資料庫中的各種鍵搞的一頭霧水。下面就跟大家一起聊聊資料庫中的那些鍵。


首先看看各種鍵的定義:


超鍵(super key):在關係中能唯一標識元組的屬性集稱為關係模式的超鍵

候選鍵(candidate key):不含有多餘屬性的超鍵稱為候選鍵

主鍵(primary key):使用者選作元組標識的一個候選鍵程式主鍵

外來鍵(foreign key)如果關係模式R1中的某屬性集不是R1的主鍵,而是另一個關係R2的主鍵則該屬性集是關係模式R1的外來鍵。



結合例項的具體解釋:


假設有如下兩個表:

學生(學號,姓名,性別,身份證號,教師編號)

教師(教師編號,姓名,工資)


超鍵:

由超鍵的定義可知,學生表中含有學號或者身份證號的任意組合都為此表的超鍵。如:(學號)、(學號,姓名)、(身份證號,性別)等。


候選鍵:

候選鍵屬於超鍵,它是最小的超鍵,就是說如果再去掉候選鍵中的任何一個屬性它就不再是超鍵了。學生表中的候選鍵為:(學號)、(身份證號)。


主鍵:

主鍵就是候選鍵裡面的一個,是人為規定的,例如學生表中,我們通常會讓“學號”做主鍵,教師表中讓“教師編號”做主鍵。


外來鍵:

外來鍵比較簡單,學生表中的外來鍵就是“教師編號”。外來鍵主要是用來描述兩個表的關係。


其實這些鍵還是比較容易區分的,只是初學者一下子看到好幾個名字相似的概念,容易自己把自己搞暈,自己給自己製造困難。多讀兩遍定義,然後結合例項很容易就能把它們區分開。希望這篇文章可以給一些初學者一點點的幫助。



相關文章