码迷,mamicode.com
首页 > 数据库 > 详细

MySQL中利用外键实现级联删除、更新

时间:2019-01-02 17:30:37      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:ict   let   文档   action   级联删除   nbsp   varchar   auto   null   

MySQL中利用外键实现级联删除、更新

  MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引。在创建索引的时候,可以指定在删除、更新父表时,对子表进行的相应操作,包括RESTRICT、NO ACTION、SET NULL和CASCADE。其中RESTRICT和NO ACTION相同,是指在子表有关联记录的情况下父表不能更新;CASCADE表示父表在更新或者删除时,更新或者删除子表对应记录;SET NULL则是表示父表在更新或者删除的时候,子表的对应字段被SET NULL。因为只有InnoDB引擎才允许使用外键,所以,我们的数据表必须使用InnoDB引擎。
我所使用的版本是Mysql5.1版本的,过程如下:

  创建数据库:

  Create database test;

  创建两个表,其中第一个表的”id”是第二个表(userinfo)的外键:

技术分享图片
1 CREATE TABLE `user` (
2 
3 `id` int(4) NOT NULL,
4 
5 `sex` enum(‘f‘,‘m‘) DEFAULT NULL,
6 
7 PRIMARY KEY (`id`)
8 
9 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
技术分享图片

 

技术分享图片
 1 CREATE TABLE `userinfo` (
 2 
 3 `sn` int(4) NOT NULL AUTO_INCREMENT,
 4 
 5 `userid` int(4) NOT NULL,
 6 
 7 `info` varchar(20) DEFAULT NULL,
 8 
 9 PRIMARY KEY (`sn`),
10 
11 KEY `userid` (`userid`),
12 
13 CONSTRAINT `userinfo_ibfk_1` FOREIGN KEY (`userid`) REFERENCES `user` (`id`)
14 ON DELETE CASCADE ON UPDATE CASCADE
15 
16 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
技术分享图片

注意:
1、存储引擎必须使用InnoDB引擎;
2、外键必须建立索引;
3、外键绑定关系这里使用了“ ON DELETE CASCADE ” “ON UPDATE CASCADE”,意思是如果外键对应数据被删除或者更新时,将关联数据完全删除或者相应地更新。更多信息请参考MySQL手册中关于InnoDB的文档;

MySQL中利用外键实现级联删除、更新

标签:ict   let   文档   action   级联删除   nbsp   varchar   auto   null   

原文地址:https://www.cnblogs.com/ysq2018China/p/10209305.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!