MySql级联删除和更新

文章来源:http://blog.csdn.net/doupei2006/article/details/7949077

(一)利用外键实现级联删除

1、先建立测试数据库

CREATE TABLE `roottb` (
  `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL,
  `data` VARCHAR(100) NOT NULL DEFAULT ‘‘,
  PRIMARY KEY (`id`)
) TYPE=InnoDB;

CREATE TABLE `subtb` (
  `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL,
  `rootid` INT(11) UNSIGNED NOT NULL DEFAULT ‘0‘,
  `data` VARCHAR(100) NOT NULL DEFAULT ‘‘,
  PRIMARY KEY (`id`),
  INDEX (`rootid`),
  FOREIGN KEY (`rootid`) REFERENCES roottb(`id`) ON DELETE CASCADE
) TYPE=InnoDB;

注意:数据表必须使用InnoDB引擎。

外键必须建立索引

外键绑定关系使用了“ on delete cascade ”

2、插入测试数据

INSERT INTO `roottb` (`id`,`data`)
  VALUES (‘1‘, ‘test root line 1‘),
         (‘2‘, ‘test root line 2‘),
         (‘3‘, ‘test root line 3‘);

INSERT INTO `subtb` (`id`,`rootid`,`data`)
  VALUES (‘1‘, ‘1‘, ‘test sub line 1 for root 1‘),
         (‘2‘, ‘1‘, ‘test sub line 2 for root 1‘),
         (‘3‘, ‘1‘, ‘test sub line 3 for root 1‘),
         (‘4‘, ‘2‘, ‘test sub line 1 for root 2‘),
         (‘5‘, ‘2‘, ‘test sub line 2 for root 2‘),
         (‘6‘, ‘2‘, ‘test sub line 3 for root 2‘),
         (‘7‘, ‘3‘, ‘test sub line 1 for root 3‘),
         (‘8‘, ‘3‘, ‘test sub line 2 for root 3‘),
         (‘9‘, ‘3‘, ‘test sub line 3 for root 3‘);

3、查看数据表的状态

4、试验级联删除功能

只删除roottb表中id为2的数据记录,看看subtb表中rootid为2的相关子纪录是否会自动删除!

mysql>; delete from `roottb` where `id`=‘2‘;
Query OK, 1 row affected (0.03 sec)

mysql>; select * from `roottb`;
+----+------------------+
| id | data             |
+----+------------------+
|  1 | test root line 1 |
|  3 | test root line 3 |
+----+------------------+
2 rows in set (0.00 sec)

mysql>; select * from `subtb`;
+----+--------+----------------------------+
| id | rootid | data                       |
+----+--------+----------------------------+
|  1 |      1 | test sub line 1 for root 1 |
|  2 |      1 | test sub line 2 for root 1 |
|  3 |      1 | test sub line 3 for root 1 |
|  7 |      3 | test sub line 1 for root 3 |
|  8 |      3 | test sub line 2 for root 3 |
|  9 |      3 | test sub line 3 for root 3 |
+----+--------+----------------------------+
6 rows in set (0.01 sec)

(二)利用触发器实现级联删除

下面给出实例

1、建立测试数据库

CREATE TABLE `root_trigger` (
  `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL,
  `data` VARCHAR(100) NOT NULL DEFAULT ‘‘,
  PRIMARY KEY (`id`)
);

CREATE TABLE `sub_trigger` (
  `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL,
  `rootid` INT(11) UNSIGNED NOT NULL DEFAULT ‘0‘,
  `data` VARCHAR(100) NOT NULL DEFAULT ‘‘,
  PRIMARY KEY (`id`)
);

2、插入测试数据

INSERT INTO `root_trigger` (`id`,`data`)
  VALUES (‘1‘, ‘test root line 1‘),
         (‘2‘, ‘test root line 2‘),
         (‘3‘, ‘test root line 3‘);

INSERT INTO `sub_trigger` (`id`,`rootid`,`data`)
  VALUES (‘1‘, ‘1‘, ‘test sub line 1 for root 1‘),
         (‘2‘, ‘1‘, ‘test sub line 2 for root 1‘),
         (‘3‘, ‘1‘, ‘test sub line 3 for root 1‘),
         (‘4‘, ‘2‘, ‘test sub line 1 for root 2‘),
         (‘5‘, ‘2‘, ‘test sub line 2 for root 2‘),
         (‘6‘, ‘2‘, ‘test sub line 3 for root 2‘),
         (‘7‘, ‘3‘, ‘test sub line 1 for root 3‘),
         (‘8‘, ‘3‘, ‘test sub line 2 for root 3‘),
         (‘9‘, ‘3‘, ‘test sub line 3 for root 3‘);

3、建立(级联/同步)删除的触发器

drop trigger if exists t_afterdelete_on_sub;
create trigger t_afterdelete_on_sub
after delete on root_trigger
for each row
begin
      delete from sub_trigger where rootid=old.id;
end;
时间: 2024-08-10 02:11:29

MySql级联删除和更新的相关文章

[原创]MYSQL中利用外键实现级联删除和更新

MySQL中利用外键实现级联删除.更新 MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引.在创建索引的时候,可以指定在删除.更新父表时,对子表进行的相应操作,包括RESTRICT.NO ACTION.SET NULL和CASCADE.其中RESTRICT和NO ACTION相同,是指在子表有关联记录的情况下父表不能更新:CASCADE表示父表在更新或者删除时,更新或者删除子表对应记录:SET NULL则是表示父表

关于数据的级联删除和更新

两张表:“ProductCategory”,“Product”. 有一个需求是这样的:在删除某个ProductCategory 的时候,同时删除该Category的products. 在MySQL中利用外键实现级联删除 创建以下测试用数据库表: CREATE TABLE `roottb` ( `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL, `data` VARCHAR(100) NOT NULL DEFAULT '', PRIMARY KEY (`i

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

MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引.在创建索引的时候,可以指定在删除.更新父表时,对子表进行的相应操作,包括RESTRICT.NO ACTION.SET NULL和CASCADE.其中RESTRICT和NO ACTION相同,是指在子表有关联记录的情况下父表不能更新:CASCADE表示父表在更新或者删除时,更新或者删除子表对应记录:SET NULL则是表示父表在更新或者删除的时候,子表的对应字段被S

mysql级联删除更新

首先,目前在产品环境可用的MySQL版本(指4.0.x和4.1.x)中,只有InnoDB引擎才允许使用外键,所以,我们的数据表必须使用InnoDB引擎. 下面,我们先创建以下测试用数据库表: CREATE TABLE `roottb` (   `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL,   `data` VARCHAR(100) NOT NULL DEFAULT '',   PRIMARY KEY (`id`) ) TYPE=InnoDB; CR

hibernate 级联删除报更新失败的问题(org.hibernate.exception.GenericJDBCException: Could not execute JDBC batch update)

首先hibernate级联删除的前提是,首先需要在映射文件中配置,配置多表之间的关联关系: 下面以部门表(Dept)和员工表(Emp)为例: 1.在Emp.hbm.xml映射文件中配置many-to-one关系 1 <?xml version="1.0"?> 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 3 "http:/

mysql级联删除

1.先创建一张主表 CREATE TABLE user ( uId INT  AUTO_INCREMENT NOT NULL PRIMARY KEY, uName  VARCHAR(100) NOT NULL); 2.创建一张从表并添加约束 create table score { sid int auto_increment not null primary key, sore numeric(10,3), uid int , FOREIGN KEY (uid ) REFERENCES use

mysql级联删除操作

mysql> CREATE TABLE `roottb` ( ->   `id` INT(11) UNSIGNED AUTO_INCREMENT NOT NULL, ->   `data` VARCHAR(100) NOT NULL DEFAULT '', ->   PRIMARY KEY (`id`) -> ) engine=InnoDB; Query OK, 0 rows affected (0.60 sec) mysql> CREATE TABLE `subtb`

【Python】Django数据模型、级联删除、级联更新、ER图导出等

在本文中,我们将向读者详细介绍如何在更新和删除父表数据的同时,触发有关子表数据的级联更新和删除操作.您将看到当使用InnoDB表的时候,借助于外键约束就可以轻松搞定这一过程. 一.利用外键约束更新并删除MySQL中的数据 我们知道,开发能够维护多个表的完整性的数据库驱动的应用程序是一件非常复杂的事情--即使应用程序所面对的是当前最流行的开源关系型数据库管理系统MySQL服务器时也不例外.如果一个应用程序必须处理多个数据库表,而这些表之间有存在着某些预定义的关系,这时一旦父表中的数据被更新或者删除

删除、更新具有外间约束的数据

在数据库使用过程中,不可避免的会遇到需要删除具有外键约束的数据这样的情况,通常有两种做法: 1.删除外键表,再删除主键表 2.给外键都加上级联现在主要介绍使用级联删除.更新约束数据.级联的意思,就是在删除.更新主键表数据时,同时删除.更新外键数据.操作方法:外键后添加:on update cascade(更新级联)On delete cascade(删除级联)例:sql server2008 添加级联:1.打开数据库,右键表名-->设计 2.右键外键字段,点击“关系”,打开“外键关系”窗口 3.