MySQL中外鍵的創建、約束以及刪除
前言
在MySQL 3.23.44版本後,InnoDB引擎類型的表支持瞭外鍵約束。
外鍵的使用條件:
1.兩個表必須是InnoDB表,MyISAM表暫時不支持外鍵(據說以後的版本有可能支持,但至少目前不支持);
2.外鍵列必須建立瞭索引,MySQL 4.1.2以後的版本在建立外鍵時會自動創建索引,但如果在較早的版本則需要顯示建立;
3.外鍵關系的兩個表的列必須是數據類型相似,也就是可以相互轉換類型的列,比如int和tinyint可以,而int和char則不可以;
外鍵的好處:可以使得兩張表關聯,保證數據的一致性和實現一些級聯操作;
一、外鍵的創建
語法一:後續添加方法
alter table 表名 add constraint 約束名 foreign key(當前表中約束的字段) references 主表表名(要約束的字段名); alter table student add constraint fk_class_student foreign key(cls_id) class(cls_id) on update cascade on delete no action;
語法二:創建表的方法
CREATE TABLE student( sid int PRIMARY KEY, cls_id int not null, sname varchar(10) not null, constraint fk_class_student foreign key(cls_id) references class(cls_id) on update cascade on delete no action )ENGINE=InnoDB DEFAULT CHARSET=utf8;
一個額外點:
SHOW CREATE TABLE class
可以查詢表的建表信息
CREATE TABLE `class` ( `cls_id` int NOT NULL, `cls_name` varchar(15) NOT NULL, PRIMARY KEY (`cls_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8
下面的演示我們就使用剛剛創建的這個學生表和班級表
內容如下
二,關於四種約束方式
在父表上進行update/delete操作時,子表的操作類型
- CASCADE 子表會刪除包含與已刪除鍵值有參照關系的所有數據
- SET NULL 父表delete、update的時候,子表會將關聯記錄的外鍵字段所在列設為null
- RESTRICT 拒絕有關聯關系的字段的刪除要求(這是默認設置,也是最安全的設置)
- NO ACTION 和RESTRICT 類似
以我們剛剛設置的外鍵為例(on update cascade on delete no action)
當我們嘗試進行刪除操作時
delete from class WHERE cls_id=1
結果如下
可以看到由於外鍵約束中on delete no action的存在,不允許對主表進行刪除操作。但是子表可以
delete from student WHERE cls_id=1
當我們對父表的關聯鍵進行更新操作時,由於on update cascade的存在,可以正常更新
UPDATE class set cls_id=4 where cls_id=1
並且隨著主表的更新,子表中的外鍵字段也進行瞭更新
三,刪除外鍵的方法
alter table 子表名 drop foreign key 外鍵約束名 alter table student drop foreign key fk_class_student
當我們將外鍵刪除之後,父表的操作就變得可以正常進行瞭
總結
到此這篇關於MySQL中外鍵創建、約束以及刪除的文章就介紹到這瞭,更多相關MySQL外鍵創建、約束及刪除內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!