欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

SQL实战41.构造一个触发器audit_log,在向employees表中插入一条数据的时候,触发插入相关的数据到audit中

程序员文章站 2022-03-05 10:33:32
...

题目

SQL实战41.构造一个触发器audit_log,在向employees表中插入一条数据的时候,触发插入相关的数据到audit中

解答

知识补充

主要借鉴的是MySQL数据库触发器讲解与案例

在MySQL中,创建触发器语法如下:

CREATE TRIGGER trigger_name trigger_time trigger_event 
ON tbl_name FOR EACH ROW
trigger_stmt

其中:
trigger_name:标识触发器名称,用户自行指定;
trigger_time:标识触发时机,取值为 BEFORE 或 AFTER;
trigger_event:标识触发事件,取值为 INSERT、UPDATE 或 DELETE;
tbl_name:标识建立触发器的表名,即在哪张表上建立触发器;
trigger_stmt:触发器程序体,可以是一句SQL语句,或者用 BEGIN 和 END 包含的多条语句,每条语句结束要分号结尾。
【NEW 与 OLD 详解】
MySQL 中定义了 NEW 和 OLD,用来表示
触发器的所在表中,触发了触发器的那一行数据。
具体地:

在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据;
在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据;
使用方法: NEW.columnName (columnName 为相应数据表某一列名)

代码

create trigger audit_log after insert on employees_test for each row
begin
    insert into audit values(new.id,new.name);
end;