程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 數據庫的主鍵與外鍵,數據庫主鍵

數據庫的主鍵與外鍵,數據庫主鍵

編輯:MySQL綜合教程

數據庫的主鍵與外鍵,數據庫主鍵


數據庫的主鍵與外鍵

一、什麼是主鍵、外鍵:

關系型數據庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能唯一標識一條記錄,該屬性組就可以成為一個主鍵 
比如  
學生表(學號,姓名,性別,班級) 
其中每個學生的學號是唯一的,學號就是一個主鍵 
課程表(課程編號,課程名,學分) 
其中課程編號是唯一的,課程編號就是一個主鍵 
成績表(學號,課程號,成績) 
成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以 學號和課程號的屬性組是一個主鍵 
  
成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,並且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外鍵 
  
同理 成績表中的課程號是課程表的外鍵 
  
定義主鍵和外鍵主要是為了維護關系數據庫的完整性,總結一下:
1.主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份正號,姓名,年齡。

身份證號是唯一能確定你這個人的,其他都可能有重復,所以,身份證號是主鍵。 
2.外鍵用於與另一張表的關聯。是能確定另一張表記錄的字段,用於保持數據的一致性。

比如,A表中的一個字段,是B表的主鍵,那他就可以是A表的外鍵。

 

 

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

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

 

主鍵

外鍵

索引

定義:

唯一標識一條記錄,不能有重復的,不允許為空

表的外鍵是另一表的主鍵, 外鍵可以有重復的, 可以是空值

該字段沒有重復值,但可以有一個空值

作用:

用來保證數據完整性

用來和其他表建立聯系用的

是提高查詢排序的速度

個數:

主鍵只能有一個

一個表可以有多個外鍵

一個表可以有多個惟一索引

 

聚集索引和非聚集索引的區別?

聚集索引一定是唯一索引。但唯一索引不一定是聚集索引。  

聚集索引,在索引頁裡直接存放數據,而非聚集索引在索引頁裡存放的是索引,這些索引指向專門的數據頁的數據。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved