-- 需求:当user表添加一行数据,则会自动在user_log添加日志记录
delimiter $$
create trigger trigger_test after insert
on user for each row
begin
	insert into user_logs values(1,now,'有新用户增加');
end $$
delimiter;
触发器操作-NEW和OLD
mysql中定义了new和old,用来表示触发器的所在表中,触发了触发器的哪一行数据,来引用触发器中发生变化的记录内容,具体如下

触发器类型

触发器类型NEW和OLD的使用

INSERT 型触发器

NEW 表示将要或者已经新增的数据

UPDATE 型触发器

OLD 表示修改之前的数据,NEW表示将要或者已经修改后的数据

DELETE 型触发器

OLD 表示将要或者已经删除的数据

使用方法: NEW.columnName(columnName为相应数据表某一列名)
demo
-- insert
	delimiter &&
	create trigger test1 after  insert
	on user for each row
	begin
		insert into user_logs values(1,now,concat('有新用户增加,信息为',NEW.uid,NEW.username,NEW.password));
	end $$
	delimiter;
-- update
delimiter &&
	create trigger test2 after update
	on user for each row
	begin
		insert into user_logs values(1,now,concat('修改用户,之前信息为',OLD.uid,OLD.username,OLD.password,'修改之后的信息为',NEW.uid,NEW.username,NEW.password));
	end $$
	delimiter;
-- delete
delimiter &&
	create trigger test3 after delete
	on user for each row
	begin
		insert into user_logs values(1,now,concat('有用户删除,信息为',OLD.uid,OLD.username,OLD.password));
	end $$
	delimiter;
触发器-查看
show triggers;
触发器-删除
drop trigger if exists trigger_test;
触发器的注意事项
① MYSQL中触发器中不能对本表进行insert,update,delete操作,以免递归循环触发
② 尽量少使用触发器,假设触发器触发每次执行1s,insert table 500条数据,那么就需要触发500次触发器,光是触发器执行的时间就要花费500s,而insert 500条数据一共是1s,那么insert的效率就非常的低了.
③ 触发器是针对每一行的,对增删改非常频繁的表上切记不要使用触发器,因为他会非常消耗资源.