sql主鍵和外來鍵有什麼區別

2022-10-09 10:39:09 字數 931 閱讀 4349

sql主鍵和外來鍵的區別:1、主鍵是唯一標識一條記錄,不能有重複,不允許為空,而外鍵可以重複,可以是空值;2、主鍵是用來保持資料完整性,外來鍵是用來建立與其他表聯絡用的;3、主鍵只有乙個,外來鍵可以有多個。

sql主鍵和外來鍵的區別:主鍵只有乙個,不能重複也不允許有空值而外鍵可以有多個,可以重複也可以有空值;主鍵是用來保持資料完整性的,外來鍵是用來與其他表建立聯絡的

什麼是主鍵、外來鍵

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

比如

學生表(學號,姓名,性別,班級)

其中每個學生的學號是唯一的,學號就是乙個主鍵

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

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

成績表(學號,課程號,成績)

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

成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,並且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外來鍵

同理成績表中的課程號是課程表的外來鍵

定義主鍵和外來鍵主要是為了維護關聯式資料庫的完整性,總結一下:

1.主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份正號,姓名,年齡。

身份證號是唯一能確定你這個人的,其他都可能有重複,所以,身份證號是主鍵。

2.外來鍵用於與另一張表的關聯。是能確定另一張表記錄的字段,用於保持資料的一致性。

比如,a表中的乙個字段,是b表的主鍵,那他就可以是a表的外來鍵。

主鍵和外來鍵的區別

(1)主鍵是唯一標識一條記錄,不能有重複,不允許為空;而外鍵可以重複,可以是空值

(2)主鍵是用來保持資料完整性,外來鍵是用來建立與其他表聯絡用的

(3)主鍵只有乙個,外來鍵可以有多個

SQL 主鍵和外來鍵約束

sql 的主鍵和外來鍵的作用 外來鍵取值規則 空值或參照的主鍵值。1 插入非空值時,如果主鍵表中沒有這個值,則不能插入。2 更新時,不能改為主鍵表中沒有的值。3 刪除主鍵表記錄時,你可以在建外鍵時選定外來鍵記錄一起級聯刪除還是拒絕刪除。4 更新主鍵記錄時,同樣有級聯更新和拒絕執行的選擇。簡而言之,s...

主鍵和唯一索引有什麼區別

create tabel t id int create unique index t index id on t id 和create tabel t id int primary key 主鍵是表中的乙個或多個字段,它的值用於惟一地標識表中的某一條記錄.使用索引可快速訪問資料庫表中的特定資訊。索...

主鍵索引和普通索引有什麼區別

在 mysql 中,索引是在儲存引擎層實現的,所以並沒有統 的索引標準,由於 innodb 儲存引擎在 mysql資料庫中使 最為 泛,下 以 innodb 為例來分析 下其中的索引模型.在 innodb 中,表都是根據主鍵順序以索引的形式存放的,innodb 使 了 b 樹索引模型,所以資料都是儲...