首页 / MYSQL / 初识MySQL(8)使用触发器
初识MySQL(8)使用触发器
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了初识MySQL(8)使用触发器,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2409字,纯文字阅读大概需要4分钟。
内容图文
![初识MySQL(8)使用触发器](/upload/InfoBanner/zyjiaocheng/878/798e744b0ece454790bc132d644892e3.jpg)
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值都转化为大写的值。
超人不会飞ilx 发布了10 篇原创文章 · 获赞 0 · 访问量 89 私信 关注内容总结
以上是互联网集市为您收集整理的初识MySQL(8)使用触发器全部内容,希望文章能够帮你解决初识MySQL(8)使用触发器所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。