DELETE触发器
触发器(trigger)是SQL server 提供

相关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字符集和校对顺序简介








