1、先创建一个空的person_log表用来存放被删除的记录。
创新互联从2013年成立,先为铜官等服务建站,铜官等地企业,进行企业商务咨询服务。为铜官企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
2、创建一个触发器del_person,执行删除操作后将记录插入到person_log表。
触发器person_log
3、从person表中执行删除记录操作来触发事件
4、查看person_log表结果:
结果:从person表执行删除一条记录后会触发person_log表中增加被删除的记录。
触发器语法:
create trriger 名称
on { tablename | viewname } [ with Encyption ]
{ for | After | instead of } [ delete | insert | update ]
as sql语句
create trriger DML1 @id int
on 表1 for insert
as
select @id=id from 表1
if (id0)
begin
insert into 表2(id) values(@id)
end
go
将delimiter ; 更改为delimiter //\x0d\x0a如下:\x0d\x0amysql delimiter //\x0d\x0amysql create trigger insertArticle_Trigger after insert on article1\x0d\x0a - for each row\x0d\x0a - begin\x0d\x0a - update board1 set articleCount = articleCount+1 where id=new.bid;\x0d\x0a - end;\x0d\x0a - //\x0d\x0a\x0d\x0a执行如下语句,可查看到board1表articleCount被更改:\x0d\x0amysql delimiter ;\x0d\x0amysql insert into article1 values(1);\x0d\x0a\x0d\x0a其中delimiter作用:\x0d\x0a告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。 \x0d\x0a默认情况下,delimiter是分号;。在命令行客户端中,如果有一行命令以分号结束, 那么回车后,mysql将会执行该命令。但有时候,不希望MySQL这么做。在为可能输入较多的语句,且语句中包含有分号。使用delimiter //,这样只有当//出现之后,mysql解释器才会执行这段语句。详见