首页  >  文章  >  数据库  >  MySQL delete触发器(删除)用法详解

MySQL delete触发器(删除)用法详解

巴扎黑
巴扎黑原创
2017-05-19 15:24:0123872浏览

DELETE触发器

触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。SQL3的触发器是一个能由系统自动执行对数据库修改的语句。

相关mysql视频教程推荐:《mysql教程

触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于强制服从复杂的业务规则或要求。例如:您可以根据客户当前的帐户状态,控制是否允许插入新订单。

DELETE 触发器在 DELETE 语句执行之前或之后执行。需要知道以下两点:

1.在 DELETE 触发器代码内,你可以引用一个名为 OLD 的虚拟表,访问被删除的行;

2.OLD 中的值全都是只读的,不能更新。下面的例子演示使用 OLD 保存将要被删除的行到一个存档表中:

输入:

create trigger deleteorder before delete on orders for each row
begin
insert into archive_orders(order_num,order_date,cust_id)
values(old.order_num,old.order_date,old.cust_id);
end;

分析:在任意订单被删除前将执行此触发器。它使用一条 INSERT 语句将 OLD 中的值(要被删除的订单)保存到一个名为 archive_orders 的存档表中(为实际使用这个例子,你需要用与 orders 相同的列创建一个名为 archive_orders 的表)。

使用 BEFORE DELETE 触发器的优点(相对于 AFTER DELETE 触发器来说)为,如果由于某种原因,订单不能存档, DELETE 本身将被放弃。

多语句触发器 正如所见,触发器 deleteorder 使用 BEGIN 和END 语句标记触发器体。这在此例子中并不是必需的,不过也没有害处。使用 BEGIN END 块的好处是触发器能容纳多条SQL语句(在 BEGIN END块 中一条挨着一条)。

【相关推荐】

1. mysql免费视频教程

2. MySQL中insert触发器(插入)详解

3. mysql触发器简介及如何创建和删除触发器

4. MySQL使用字符集和校对顺序使用教程

5. MySQL字符集和校对顺序简介

以上是MySQL delete触发器(删除)用法详解的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn