日韩性视频-久久久蜜桃-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)来进行级联更新、删除的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: av免播放器在线观看 | 久久久久久久久久电影 | 玖玖爱资源站 | 欧美熟妇精品黑人巨大一二三区 | 免费一级欧美 | 一区二区三区免费在线视频 | 国产精品成人一区二区三区 | 91免费版在线| 啪啪一级片 | 又污又黄又爽的网站 | 国产免费一区二区三区网站免费 | 简单av网| 亚洲熟女乱综合一区二区三区 | 操极品少妇 | 国产精品短视频 | 久久久夜夜 | 黄色网址链接 | 顶级毛茸茸aaahd极品 | av资源站最新av | jiuse九色 | 草草影院在线免费观看 | 日韩黄色片免费看 | 木下凛凛子av一区二区三区 | 成年人观看视频 | 美女被啪啪 | 亚洲激情av在线 | 在线观看一区二区三区视频 | 大战熟女丰满人妻av | 国产男男网站 | 美女成人在线 | 国产一区二区在线免费 | 午夜精品福利在线观看 | 今天高清视频在线观看视频 | 黑人与日本少妇 | 揄拍自拍 | 啪啪网站视频 | 国产精品污www在线观看 | 久久国产精品精品国产色婷婷 | 久热中文| 播放黄色一级片 | 久久久久国产 | 欧美 日韩 国产 激情 | 都市激情 亚洲 | 国产精品午夜福利视频234区 | 国产成人一级 | 大白屁股一区二区视频 | 操在线视频 | 欧美粗暴se喷水 | 欧美韩日一区二区 | 成人免费在线视频观看 | 中文字幕日韩在线播放 | 在线观看亚洲免费视频 | 不卡网av| 亚洲蜜桃精久久久久久久久久久久 | 亚洲激情网 | 国产另类在线 | 超碰久操| av色综合 | 在线观看黄色片 | 日韩色 | 伊人久久免费视频 | av免费看网址 | 综合久 | 成人人伦一区二区三区 | 红猫大本营在线观看的 | 亚洲精品免费播放 | 综合在线观看 | 国产乱子伦一区二区 | 免费涩涩网站 | 俄罗斯黄色大片 | 欧美狂猛xxxxx乱大交3 | 日韩美女一区 | 国产精品国产馆在线真实露脸 | а√天堂8资源在线官网 | 亚洲av成人精品毛片 | 青青草国产一区二区三区 | 无码国产精品一区二区免费式直播 | 成人国产在线观看 | 精品人妻二区中文字幕 | 日韩av高清在线播放 | 黄色一级一级 | 美女毛片在线观看 | av在线免费不卡 | 尤物视频在线播放 | 精品无码久久久久久久久成人 | 久久久看| 国产xxxx| 中文字幕a√ | 偷拍老头老太高潮抽搐 | 美日韩在线视频 | 国产三区视频 | 国产91在线播放九色 | 国产情侣酒店自拍 | 99综合| 欧美爽爽爽 | 传媒视频在线观看 | 三级免费 | 日韩精品在线观看中文字幕 | 午夜精品久久99蜜桃的功能介绍 |