首頁 > 資料庫 > mysql教程 > 了解MySQL中的外鍵作用

了解MySQL中的外鍵作用

coldplay.xixi
發布: 2020-08-31 16:59:36
轉載
2584 人瀏覽過

了解MySQL中的外鍵作用

【相關學習推薦:#mysql學習

#MySQL外鍵的作用:

保持資料一致性,完整性,主要目的是控制儲存在外鍵表中的資料。使兩張表形成關聯,外鍵只能引用外表中列的值!

我們來建立兩個表

CREATE TABLE `example1` (
  `stu_id` int(11) NOT NULL DEFAULT '0',
  `course_id` int(11) NOT NULL DEFAULT '0',
  `grade` float DEFAULT NULL,
  PRIMARY KEY (`stu_id`,`course_id`)
);
CREATE TABLE `example2` (
  `id` int(11) NOT NULL,
  `stu_id` int(11) DEFAULT NULL,
  `course_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `f_ck` (`stu_id`,`course_id`),
  CONSTRAINT `f_ck` FOREIGN KEY (`stu_id`, `course_id`) REFERENCES `example1` (`stu_id`, `course_id`)
);
insert into example1 (stu_id,course_id,grade)values(1,1,98.5),(2,2,89);
insert into example2 (id,stu_id,course_id)values(1,1,1),(2,2,2);
登入後複製

我們建立了

example1表,裡麵包含stu_id學號,course_id課程號,grade分數

example2表,裡麵包含id,stu_id學號,course_id課程號,然後建立外鍵

分別插入資料到兩個表中。

我們把example2中的stu_id和course_id稱為example2表的外鍵,example1是父表,example2是字表,兩個表形成關聯,必須字表的資料刪除後,才能刪除父表中的對應資料

現在我們來刪除example1中的一條資料

delete from example1 where stu_id=2;
登入後複製

會發現報錯

ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`test`.`example3`, CONSTRAINT `f_ck` FOREIGN KEY (`stu_id`, `course_id`) REFERENCES `example2` (`stu_id`, `course_id`))##example2` (`stu_id`, `course_id`))##example2`ample#p中的數據關聯了example1的數據,這樣是刪不了的,達到了外鍵的作用;

然後我們來先刪除example2表中的數據,再刪除example1表中的數據

delete from example2 where stu_id=2;

delete from example1 where stu_id=2;

這樣就成功了;

事件觸發限制:

on delete和on update , 可設參數cascade(跟隨外鍵改動), restrict(限制外表中的外鍵改動),set Null(設空值),set Default(設預設值),[預設]no action

我們來看看事件觸發限制是幹嘛的。 。 。

我們先刪除外鍵,然後重新建立外鍵帶上事件觸發限制

alter table example2 drop foreign key f_ck; alter table example2 add CONSTRAINT `f_ck` FOREIGN KEY (`stu_id` , `course_id`) REFERENCES `example1` (`stu_id`, `course_id`) ON DELETE CASCADE ON UPDATE CASCADE;

我們先查看資料

mysql> selectse * from example2;

+--------+-----------+-------+

| stu_id | course_id | grade |

+--------+-----------+-------+

|      1 |         1 |  98.5 |

+--------+-----------+-------+

1 row in set (0.00 sec)

+----+--------+-----------+

| id | stu_id | course_id |

+----+--------+-----------+

|  1 |      1 |         1 |

+----+--------+-----------+

1 row in set (0.00 sec)
登入後複製
這時example1和example2中的stu_id和course_id都是1,

#再來修改example1表中的資料看看

update example1 set stu_id =3,course_id=3 where stu_id=1;

再來查看資料

mysql> select * from example1;select * from example2;

+--------+-----------+-------+

| stu_id | course_id | grade |

+--------+-----------+-------+

|      3 |         3 |  98.5 |

+--------+-----------+-------+

1 row in set (0.00 sec)

+----+--------+-----------+

| id | stu_id | course_id |

+----+--------+-----------+

|  1 |      3 |         3 |

+----+--------+-----------+

1 row in set (0.00 sec)
登入後複製
發現沒,example1和example2中的stu_id和course_id都變成了3

我們在來刪除example1表中的資料

delete from example1 where stu_id=3;

#會發現可以刪除,而且example2中的資料也沒有了;

其實啊,外鍵就這個作用,保持資料一致性,完整性,是不讓改還是一起改,由事件觸發器決定;

相關學習推薦:
程式設計影片

#

以上是了解MySQL中的外鍵作用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:oschina.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板