一、触发器有什么作用?
触发器是和表关联的特殊的存储过程,可以在插入,删除或修改表中的数据时触发执行,比数据库本身标准
的功能有更精细和更复杂的数据控制能力。
1、触发器的优点
1.安全性
2.审计
3.实现复杂的数据完整性规则
4.提供了运行计划任务的另一种方法
2、触发器有哪些要素?
1.监控地点:table;
2.监控事件:insert/update/delete;
3 触发时间:after/before;
4.触发事件:insert/update/delete。
2、创建触发器
一.创建触发器的基本语法如下所示:
CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name FOR EACH ROW trigger_stmt
trigger_name:触发器的名称;
tirgger_time:触发时机,为 BEFORE 或者 AFTER;
trigger_event:触发事件,为 INSERT、DELETE 或者 UPDATE;
tb_name:表示建立触发器的表名,在哪张表上建立触发器;
trigger_stmt:触发器的程序体,可以是一条 SQL 语句或者是用 BEGIN 和 END 包含的多条语句;
FOR EACH ROW 表示任何一条记录上的操作满足触发事件都会触发该触发器。
注意:对同一个表相同触发时间的相同触发事件,只能定义一个触发器。
.示例
创建触发器,当用户购买 p30 时,同时更新 p30 库存记录
-- 创建触发器
create trigger mytg1
after insert on orders
for each row
begin
update product set num = num-3 where pid=1;
end;
-- 往订单表插入记录
insert into orders values