初识MySQL(8)使用触发器

混江龙づ霸主 提交于 2020-01-27 14:35:04

1.触发器的作用

当一个SQL语句被执行之后,我们可能会需要一些事情自动发生:
(1)每当增加一个顾客到数据库表的时候,都检查其电话号码格式是否正确;
(2)每当订购一个产品时,都从库存数量中减去订购的数量;
(3)无论何时删除一行,都在某个存档表中保留一个副本。

所有例子的共同之处是他们都需要在某个表发生变动的时候自动处理一些事情,这就是触发器。
触发器支持DELETE,INSERT,UPDATE语句,其他语句不支持触发器。

2.创建触发器

在我们创建一个触发器的时候,我们需要给出一下4个信息:
(1)唯一的触发器名
(2)触发器关联的表
(3)触发器应该响应的活动(DELETE,UPDATE,INSERT)
(4)触发器何时执行(处理前或处理后)

创建触发器的一个例子:

CREATE TRIGGER newproduct AFTER INSERT ON products FOR EACH ROW SELECT 'Product added';

以上创建触发器的例子,表明了这是一个针对表products的触发器,并且响应的活动是INSERT操作,并在操作处理之后启动触发器,而FOR EACH ROW SELECT 'Product added’指的就是在每一行的插入操作之后文本’Product added’均会被显示。
注意,只有表支持触发器,视图并不支持触发器!

3.删除触发器

DROP TRIGGER newproduct;

4.使用触发器

INSER触发器:
在使用INSERT触发器的时候,我们引入一个新的概念,就是一个名为NEW的虚拟表,来表示插入完成之后的新表,然后用NEW来访问被插入的行。
NEW表中的值可以被更新。

CREATE TRIGGER neworder AFTER INSERT ON orders FOR EACH ROW SELECT NEW.order_num;

此代码创建了一个名为neworder的触发器,他按照AFTER INSERT在order表上运行。在插入了一个新的行之后,生成一个新的订单号并保存到order_num中。触发器从NEW.order_num取得这个值并返回他。

DELETE触发器
在使用DELETE触发器的时候,相对应的也有一个OLD的虚拟表,来表示删除之前的旧表,然后用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语句将删除的那一行保存在一个名为archive_orders的表中。
上面例子使用了BEGIN/END结构,用于在触发器有多条SQL语句时容纳,使得代码整体的结构比较清晰明确,不过在上述例子中其实并不是必要的。

UPDATE触发器
同理,UPDATE可以对操作前和操作后的表都进行操作,因此NEW和OLD都可以在UPDATE触发器中使用。使用道理与上面的两种情况相同。

CREATE TRIGGER updateevendor BEFORE UPDATE ON vendors
FOR EACH ROW SET NEW.vend_state = Upper(NEW.vend_state);

以上语句实现的功能就是在每一次进行更新的行的vend_state值都转化为大写的值。

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!