首頁 > 軟體

MySQL外來鍵約束詳解

2022-07-29 14:03:56

今天繼續給大家介紹MySQL相關知識,本文主要內容是MySQL外來鍵約束詳解。

一、MySQL外來鍵約束作用

外來鍵約束(Foreign Key)即資料庫中兩個資料表之間的某個列建立的一種聯絡。這種聯絡通常是以實際場景中含義完全相同的欄位所造成的。MySQL通過外來鍵約束的引入,可以使得資料表中的資料完整性更強,也更符合顯示情況。下面,我舉一個例子來說明MySQL外來鍵約束的作用。
假如我們對大學學生成績管理系統建立資料庫,有兩張表,一張表是學生表,儲存了學生的學號、姓名、性別、院系等資訊,還有一張表是成績表,儲存了學生學號、課程編號、考試成績等資訊。這樣,這兩張表之間就會通過學生學號建立外來鍵約束。很自然的我們想到,成績表的學生學號依賴於學生表的學生學號存在,如果一個學生畢業、或者退學,從學生表中刪除時,那麼他的相關成績也就沒有必要在成績表中存在了。在沒有建立外來鍵關係之前,這兩張表完全是獨立存在的,我們可以強行在成績表中插入一個不存在學生的相關成績,也可以強行刪除學生表中的一個學生,並且不管其成績資訊是否在成績表中存在。但是,在建立外來鍵關係後,MySQL資料庫會約束上述兩種行為,每次對資料進行插入或者刪除時,都會檢查資料完整性,使得我們的操作必須符合實際情況。

二、外來鍵約束建立

(一)建立外來鍵約束的條件

MySQL資料庫外來鍵的建立,需要滿足以下四個條件,否則會被MySQL資料庫拒絕:
1、建立外來鍵的表和列存在
2、組成外來鍵的列存在索引
3、必須指定資料表的引擎為InnoDB
4、外來鍵欄位和關聯欄位,資料型別必須一致

(二)在建立資料表時建立外來鍵約束

在建立資料表時建立外來鍵約束,只需要在建立資料表的create語句後面,使用foreign key關鍵字指定本表的外來鍵欄位,使用reference關鍵字指定關聯表的關聯欄位,並且明確約束行為即可。
建立外來鍵約束的SQL語句範例如下:

create table student (id int(8),name varchar(20),department varchar(20) ,index (id))ENGINE=InnoDB;
create table grade (Sid int(8),Cid int(10),score int,index(Sid),foreign key (Sid) references student(id) on  delete  restrict on update cascade)ENGINE=InnoDB;

在上述SQL語句中,on delete restrict 是指明在刪除時外來鍵會對該刪除操作進行限制,而on update cascade是指名在更新時會對該更新操作進行同步。

(三)在建立資料表後新增外來鍵約束

同樣的,MySQL也支援在建立資料表後再新增外來鍵約束。在上例中,我們先刪除grade表,然後再建立grade表,現不建立外來鍵,嘗試在建立grade表後新增外來鍵,相關SQL命令如下:

drop table grade;
create table grade(Sid int(8),Cid int(10),score int);
alter table grade add index(Sid);
alter table grade add foreign key (Sid) references student(id) on delete restrict on update cascade;

執行結果如下:

三、外來鍵約束功能演示

下面,我們就來測試一下外來鍵約束的功能,首先,嘗試向grade表插入一個不存在學生的成績,發現被拒絕:

之後,嘗試刪除student表中存在成績的學生,發現被拒絕:

緊接著,我們測試一下MySQL外來鍵約束級聯更新功能,發現,如果更改了student表中的資料,grade表也會跟著變動,如下所示:

 到此這篇關於MySQL外來鍵約束詳解的文章就介紹到這了,更多相關Mysql外來鍵約束 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com