SQL Server —— 主鍵和外鍵


一、定義

1.1、什么是主鍵和外鍵

關系型數據庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能唯一標識一條記錄,該屬性組就可以成為一個主鍵。

 

比如:

學生表(學號,姓名,性別,班級)
其中每個學生的學號是唯一的,學號就是一個主鍵。

 

課程表(課程編號,課程名,學分)

其中課程編號是唯一的,課程編號就是一個主鍵。

 

成績表(學號,課程號,成績)
成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以 學號和課程號的屬性組是一個主鍵。

 

1.2、主鍵和外鍵的作用

(1)、為了維護關系數據庫的完整性

主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份證號,姓名,年齡。身份證號是唯一能確定你這個人的,其他都可能有重復,所以,身份證號是主鍵。

外鍵用於與另一張表的關聯。是能確定另一張表記錄的字段,用於保持數據的一致性。比如,A表中的一個字段,是B表的主鍵,那他就可以是A表的外鍵。

 

(2)、起約束作用

外鍵取值規則:空值或參照的主鍵值。

  • 插入非空值時,如果主鍵表中沒有這個值,則不能插入。
  • 更新時,不能改為主鍵表中沒有的值。
  • 刪除主鍵表記錄時,你可以在建外鍵時選定外鍵記錄一起級聯刪除還是拒絕刪除。
  • 更新主鍵記錄時,同樣有級聯更新和拒絕執行的選擇。

 

1.3、主鍵、外鍵和索引的區別

區別 主鍵 外鍵 索引
定義 唯一標識一條記錄,不能有重復的,不允許為空 表的外鍵是另一表的主鍵, 外鍵可以有重復的, 可以是空值 該字段沒有重復值,但可以有一個空值
作用 用來保證數據完整性 用來和其他表建立聯系用的 是提高查詢排序的速度
個數 主鍵只能有一個 一個表可以有多個外鍵 一個表可以有多個唯一索引


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM