本文实例讲述了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)的外键:

CREATE TABLE `user` (

`id` int(4) NOT NULL,

`sex` enum('f','m') DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=latin1;

CREATE TABLE `userinfo` (

`sn` int(4) NOT NULL AUTO_INCREMENT,

`userid` int(4) NOT NULL,

`info` varchar(20) DEFAULT NULL,

PRIMARY KEY (`sn`),

KEY `userid` (`userid`),

CONSTRAINT `userinfo_ibfk_1` FOREIGN KEY (`userid`) REFERENCES `user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE

) ENGINE=InnoDB DEFAULT CHARSET=latin1;

注意:

1、存储引擎必须使用InnoDB引擎;

2、外键必须建立索引;

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

好,接着我们再来插入数据测试:

INSERT INTO `user` (`id`,`sex`)

VALUES ('1', 'f'), ('2', 'm'), ('3', 'f');

INSERT INTO `userinfo` (`sn`,`userid`,`info`)

VALUES ('1', '1', '2005054dsf'),

('2', '1', 'fdsfewfdsfds'),

('3', '1', 'gdsgergergrtre'),

('4', '2', 'et34t5435435werwe'),

('5', '2', '435rtgtrhfghfg'),

('6', '2', 'ret345tr4345'),

('7', '3', 'fgbdfvbcbfdgr'),

('8', '3', '45r2343234were'),

('9', '3', 'wfyhtyjtyjyjy');

我们先看一下当前数据表的状态:

mysql> show tables;

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

| Tables_in_test |

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

| user |

| userinfo |

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

2 rows in set (0.00 sec)

User表中的数据:

mysql> select * from user;

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

| id | sex |

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

| 1 | f |

| 2 | m |

| 3 | f |

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

3 rows in set (0.00 sec)

Userinfo表中的数据:

mysql> select * from userinfo;

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

| sn | userid | info |

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

| 1 | 1 | 2005054dsf |

| 2 | 1 | fdsfewfdsfds |

| 3 | 1 | gdsgergergrtre |

| 4 | 2 | et34t5435435werwe |

| 5 | 2 | 435rtgtrhfghfg |

| 6 | 2 | ret345tr4345 |

| 7 | 3 | fgbdfvbcbfdgr |

| 8 | 3 | 45r2343234were |

| 9 | 3 | wfyhtyjtyjyjy |

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

9 rows in set (0.00 sec)

对于建立以上不表,相信对大家也没什么难度了。好的,下面我们就要试验我们的级联删除功能了。

我们将删除user表中id为2的数据记录,看看userinf表中userid为2的相关子纪录是否会自动删除:

执行删除操作成功!

mysql> delete from `user` where `id`='2';

Query OK, 1 row affected (0.03 sec)

看看user表中已经没有id为2的数据记录了!

mysql> select * from user;

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

| id | sex |

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

| 1 | f |

| 3 | f |

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

2 rows in set (0.00 sec)

再看看userinfo表中已经没有userid为2的3条数据记录了,对应数据确实自动删除了!

mysql> select * from userinfo;

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

| sn | userid | info |

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

| 1 | 1 | 2005054dsf |

| 2 | 1 | fdsfewfdsfds |

| 3 | 1 | gdsgergergrtre |

| 7 | 3 | fgbdfvbcbfdgr |

| 8 | 3 | 45r2343234were |

| 9 | 3 | wfyhtyjtyjyjy |

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

6 rows in set (0.00 sec)

更新的操作也类似,因为我们在前面建表的时候已经定义外键删除、更新操作都是CASCADE,所以在这里可以直接测试数据。

将user表中原来id为1的数据记录更改为id为4,执行如下:

mysql> update user set id=4 where id='1';

Query OK, 1 row affected (0.03 sec)

Rows matched: 1 Changed: 1 Warnings: 0

现在去看看两个表中是数据是否发生了变化:

mysql> select * from user;

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

| id | sex |

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

| 3 | f |

| 4 | f |

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

2 rows in set (0.00 sec)

mysql> select * from userinfo;

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

| sn | userid | info |

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

| 1 | 4 | 2005054dsf |

| 2 | 4 | fdsfewfdsfds |

| 3 | 4 | gdsgergergrtre |

| 7 | 3 | fgbdfvbcbfdgr |

| 8 | 3 | 45r2343234were |

| 9 | 3 | wfyhtyjtyjyjy |

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

6 rows in set (0.00 sec)

比较原来的表可以发现它们的确已经更新成功了,测试完成!!!这也就实现了用外键对多个相关联的表做同时删除、更新的操作,从而保证了数据的一致性。

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

本文标题: MySQL使用外键实现级联删除与更新的方法

本文地址: http://www.cppcns.com/shujuku/mysql/156002.html

mysql创建外键级联更新_MySQL使用外键实现级联删除与更新的方法相关推荐

  1. mysql存在外键的连接_MySQL(外连接、自然连接、新增-追加-删除外键、外键条件-约束)...

    外连接(outer join) left join:左外连接(左连接),以左表为主表 right join:右外连接(右连接),以右表为主表 基本语法:左表 left/right join 右表 on ...

  2. mysql创建表设置自增_mysql 创建表并设置主键自增

    mysql 创建表并设置主键自增 mysql 创建表: mysql> create table user( -> userid int(4) primary key not null au ...

  3. mysql创建表时添加范式_MySql三大范式与数据库设计和表创建常用语句

    [数据库设计的三大范式] 1.第一范式(1NF First Normal Fromate):数据表中的每一列(字段),必须是不可拆分的最小单元.也就是确保每一列的原子性. 例如: userInfo: ...

  4. mysql设置主键的作用_mysql设置主键有什么用

    mysql设置主键的作用是:1.唯一地标识表中的每一行,通过它可强制表的实体完整性:2.主要是用于其他表的外键关联,以及本记录的修改与删除. [相关学习推荐:mysql教程] mysql设置主键的作用 ...

  5. mysql的判断更新_mysql判断记录是否存在,存在则更新,不存在则插入

    向数据库插入记录时,有时会有这种需求,当符合某种条件的数据存在时,去修改它,不存在时,则新增,也就是saveOrUpdate操作.这种控制可以放在业务层,也可以放在数据库层,大多数数据库都支持这种需求 ...

  6. mysql创建表并指定字符集_mysql 创建表 指定字符集

    不知道你是不是想像下面那样作转换: CREATE TABLE `books` ( `id` varchar(8) NOT NULL default '', `name` varchar(24) def ...

  7. mysql 主键 sql语句_Mysql 增加主键或者修改主键的sql语句操作

    添加表字段 alter table table1 add transactor varchar(10) not null; alter table table1 add id int unsigned ...

  8. mysql 外键报错_MySQL添加外键、删除外键方式,MySQL删除外键报错快速解决方案...

    外键的作用主要在于对各类表单进行约束,避免出现冗余数据及超出数据.那么,MySQL如何添加与删除外键?添加删除外键时报错是什么原因? 本文将从创建MySQL表单时添加外键.给已存在表单添加外键.删除外 ...

  9. mysql中平方米显示不出来_MySQL - 添加外键

    目录 整理了一下这个知识,虽然很简单哈,为了以后的方便. 为已经添加好的数据表添加外键 语法: alter table 表名 add constraint FK_ID foreign key(你的外键 ...

最新文章

  1. 【转】NuGet.org 无法访问的解决方法
  2. Fiddler之为什么我没有抓到网络请求的js链接
  3. 遍历map集合常用的4种方式
  4. 企业传播需要拥有的5个风险意识
  5. 魔百盒M301H-ZN代工-卡刷刷机固件
  6. 201621123062《java程序设计》第11周作业总结
  7. 电脑启用网络发现以后在点开又成关闭状态了,导致网上邻居访问不了 。如何处理
  8. 正则表达式匹配标签里面的内容
  9. 13. Linux权限管理命令
  10. Java中的函数(方法)
  11. 工控网关linux用什么芯片,重庆工控嵌入式主板原理,工业网关怎么挑
  12. nyoj 82-迷宫寻宝(一) (多重BFS)
  13. 【黑金动力社区】【FPGA黑金开发板】Verilog HDL的礼物 - Verilog HDL扫盲文
  14. mac php oci,PHP:OCI安装
  15. Google AIY人工智能套件,让STEM教育更加生动有趣!
  16. tarjan习题题解
  17. Modbus通讯协议常用功能码解释
  18. vite实现md转vue
  19. 字符串取出年,月,日
  20. 微信改版 | 从开屏动画看微信与头条理念之争

热门文章

  1. 减肥平台期突破宝典,你必须拥有!
  2. Windows Azure 常见问题汇总
  3. .NET Core 和 ASP.NET 5 RC1 发布
  4. 如何科学预测后代的身高
  5. 给“习得性无助”者的回信
  6. 任意十六进制数转换成十进制数----不管你输入多长都能转换
  7. 猿团股权投资:开启短平快的全新投融模式
  8. Unity台北場優化分享 达哥 讲 Unity优化
  9. YUV是究竟什么意思
  10. 一点、两点、三点透视投影的python3实现-计算机图形学