zl程序教程

您现在的位置是:首页 >  其他

当前栏目

触发器

2023-02-26 12:28:04 时间

一、什么是触发器:

1、触发器是由事件来触发某个操作,这些事件包括insert、update和delete语句。
2、触发器实际是个特殊的存储过程,如果定义了触发程序,当数据库执行这些语句的时候就会激发触发器执行相应的操作;
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。
3、触发器可以查询其他表,而且可以包含复杂的SQL语句。主要用于满足复杂的业务规则或要求。

(福利推荐:阿里云、腾讯云、华为云服务器最新限时优惠活动,云服务器1核2G仅88元/年、2核4G仅698元/3年,点击这里立即抢购>>>

二、创建触发器:
1.语法:

create trigger trigger_name trigger_time trigger_event on table_name for each row  trigger_statement; 

(1)trigger_name:触发器名称
(2)trigger_time:触发时机,before或after

before:先完成触发,再增删改,触发的语句先用于监视的增删改,我们就有机会判断、修改即将发生的操作。 after:先完成数据的增删改,再触发,触发的语句晚于监视的增删改操作,无法影响前面的增删改动作。

(3)trigger_event:触发事件,包括insert、update、delete
(4)table_name:表名,即在哪张表上建立触发器
(5)trigger_statement:触发器的程序体,对于多行语句,可以使用begin和end作为开始和结束。

在MySQL触发器中的SQL语句可以关联表中的任意列。但不能直接使用列的名称去标志,那会使系统混淆,因为激活触发器的语句可能已经修改、删除或添加了新的列名,而列的旧名同时存在。
因此必须用这样的语法来标志:“NEW.column_name”或者“OLD.column_name”。
NEW.column_name用来引用新行的一列;
OLD.column_name用来引用更新或删除它之前的已有行的一列。
对于INSERT语句,只有NEW是合法的;
对于DELETE语句,只有OLD才合法;而UPDATE语句可以与NEW或OLD同时使用。

注意事项:
不能在一个表内创建两个(包含两个)以上trigger_time和 trigger_event相同的触发器。

触发器


本站部分内容转载自网络,版权属于原作者所有,如有异议请联系QQ153890879修改或删除,谢谢!
转载请注明原文链接:触发器

你还在原价购买阿里云、腾讯云、华为云、天翼云产品?那就亏大啦!现在申请成为四大品牌云厂商VIP用户,可以3折优惠价购买云服务器等云产品,并且可享四大云服务商产品终身VIP优惠价,还等什么?赶紧点击下面对应链接免费申请VIP客户吧:

1、点击这里立即申请成为腾讯云VIP客户

2、点击这里立即注册成为天翼云VIP客户

3、点击这里立即申请成为华为云VIP客户

4、点击这里立享阿里云产品终身VIP优惠价

喜欢 (0)
[[email protected]]
分享 (0)