日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MYSQL_使用外键约束(constraint)或触发器(trigger)来进行级联更新、删除

發布時間:2025/6/15 数据库 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MYSQL_使用外键约束(constraint)或触发器(trigger)来进行级联更新、删除 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我們通常有這樣的需求:刪除表Table 1中記錄,需要同時刪除其它表中與Table 1有關的若干記錄。

舉個例子:

現有2個實體- 麻將機 學生、課程,1種聯系- 成績

分別創建 學生表 students, 課程表course,成績表score

--創建 學生表 students

CREATE TABLE IF NOT EXISTS `students` (

?`id` int(11) NOT NULL AUTO_INCREMENT,

?`name` varchar(32) DEFAULT "",

?PRIMARY KEY (`id`)

) ENGINE=InnoDB;

?

--插入若干記錄

INSERT INTO `students` (`id`, `name`) VALUES

(1, "john"),

(2, "lucy"),

(4, "jack");

?

--創建課程表

CREATE TABLE IF NOT EXISTS `course` (

?`id` int(11) NOT NULL AUTO_INCREMENT,

?`name` varchar(32) DEFAULT "",

?PRIMARY KEY (`id`)

) ENGINE=InnoDB;

?

-- 插入數據若干

INSERT INTO `course` (`id`, `name`) VALUES

(1, "english"),

(2, "chinese"),

(3, "math");

?

--創建成績表

--sid 學生id

--cid 課程id

CREATE TABLE IF NOT EXISTS `score` (

?`sid` int(11) DEFAULT "0",

?`cid` int(11) DEFAULT "0",

?`score` float(6,2) DEFAULT "0.00",

?KEY `sid` (`sid`),

?KEY `cid` (`cid`)

) ENGINE=InnoDB;

?

--插入若干數據

INSERT INTO `score` (`sid`, `cid`, `score`) VALUES

(1, 2, 95.00),

(1, 3, 65.00),

(2, 1, 77.00),

(2, 2, 68.50),

(2, 3, 89.00);

現在,我希望:

刪除students表記錄的同時,自動刪除成績表中該同學的記錄

刪除course表記錄的同時,自動刪除成績表中該課程的記錄

我想到的做法有二:

一,使用innodb表的外鍵約束

ALTER TABLE `score`

ADD CONSTRAINT `student_ibfk1`

FOREIGN KEY `sid`(`sid`) REFERENCES `students` (`id`)

ON DELETE CASCADE ON UPDATE CASCADE;

這里CASCADE作用就是在父表記錄更新或刪除時,子表更新或刪除相應的記錄

外鍵約束的動作除了CASCADE,還有RESTRICT(限制刪除)SET NULL(設為空值,字段如果允許為空的話)等

外鍵約束文檔詳見:http://dev.mysql.com/doc/refman/5.0/en/innodb-foreign-key-constraints.html

二,使用觸發器trigger進行操作

由于外鍵約束只能用于Innodb型表,因些對于MyIsam型表還得用trigger來進行更新

--以下觸發器在刪除students后同時刪除表score中相關記錄

DROP TRIGGER IF EXISTS `deleteScore`//

CREATE TRIGGER `deleteScore` AFTER DELETE ON `students`

?FOR EACH ROW BEGIN

DELETE FROM score WHERE sid=OLD.`id`;

END

//

觸發器比較好理解,其中AFTER是事件發生后,有的需求可能用BEFORE;事件類型有INSERT,REPLACE,UPDATE,DELETE等

這里的”//”是delimiter,用來標記觸發器開始與結束

總結

以上是生活随笔為你收集整理的MYSQL_使用外键约束(constraint)或触发器(trigger)来进行级联更新、删除的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。