触发器是一个特殊的存储过程,在事件delete、insert、update发生时自动执行一条或多条SQL语句(执行多条SQL语句需要用begin、end 包裹起来)
创建触发器的四大必要条件
创建触发器语句示例
CREATE TRIGGER 触发器名称
BEFORE|AFTER 事件
ON 关联的数据表
FOR EACH ROW
--单条SQL语句
INSERT xxxxx on xxx;
--多条语句用begin、end包裹
--BEGIN
-- INSERT xxxxx on xxx;
-- UPDATE xxx where xxx;
--END
show triggers;
DROP trigger if exists 触发器名;
注意:只有数据表才支持触发器,视图和临时表都不支持,每个表最多支持6个触发器(每条insert、update、delete的before和after),单一触发器不能与多个事件和多个表关联
insert触发器在insert语句执行之前(before)或者执行之后(after)执行,在insert触发器代码内,可以引用一个名为"NEW
" 的虚拟表,访问被插入的行。
在before insert 触发器中,NEW 中的值可以被更新
对于QUTO_INCREMENT 的列,NEW 在 insert执行之前包含0,执行之后包含新的自动生成值
示例
--在插入记录后返回新增的id
CREATE TRIGGER mytrigger
AFTER insert
ON mytable
FOR EACH ROW
select NEW.id
delete触发器在delete语句执行之前(before)或者执行之后(after)执行,在insert触发器代码内,可以引用一个名为"OLD
" 的虚拟表,访问被删除的行。
虚拟表OLD中的值是只读的
示例
--把删除的记录存档
CREATE TRIGGER mytrigger
AFTER delete
ON mytable
FOR EACH ROW
begin
isnert into mytemp(id,name) values(OLD.id,OLD.name);
end;
update触发器在update语句执行之前(before)或者执行之后(after)执行,在update触发器代码内,可以引用一个名为"OLD
" 的虚拟表,访问旧记录。引用一个名为"NEW
" 的虚拟表访问新更新的值。
在before update触发器中,NEW 中的值可以被更新
虚拟表OLD中的值是只读的
示例
--更新记录时,保证名字总是大小的
CREATE TRIGGER mytrigger
before update
ON mytable
FOR EACH ROW
begin
set NEW.NAME = Upper(NEW.NAME);
end;