触发器是用户定义事务命令的集合,当对一个表进行INSERT、UPDATE和DELETE操作时,会自动执行这些命令,保证数据的完整性和安全性。
触发器按执行语句分可分为:一条执行语句的触发器和多条执行语句的触发器。
1、创建有一条执行语句的触发器
语法形式:
create trigger trigger_name
before|after trigger_event
on table_name for each row trigger_stmt;
其中before|after参数指定了触发器执行的时间,前者指定在触发器事件之前执行触发器语句,后者指定在触发器事件之后执行触发器语句。
for each row参数表示任何一条记录上的操作满足触发器事件都会出发该触发器。
trigger-event表示触发器执行条件;trigger-stmt表示激活触发器后被执行的语句。
创建表,然后创建单条执行语句的触发器
向表中插入一条数据,启动触发器,查看触发器执行的SQL结果。
2、创建多条执行语句的触发器
语法形式:
create trigger trigger_name
before|after trigger_event
on table_name for each row
begin
trigger_stmt
end
多条执行语句的触发器,位于begin和end之间,多条执行语句之间用;隔开
采用关键字delimiter关键字设置结束符号,插入记录后,由于原来的触发器还在,所以查询结果多了三条新记录。
3、通过show triggers语句查看触发器
4、通过查看系统表trigger实现查看触发器
5、删除触发器
语法形式:
drop trigger triggrt_name;
查看触发器,删除触发器,再次查看触发器。