|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
对于insert和delete,event中包含了插入/删除的记录的所有字段的值(太爽了。。)sql|触发器|备份|数据库起首,你必要创建测试数据表,一个用于拔出数据:test3,别的一个作为备份:test3_bak
以下是援用片断为例:
createtabletest3(idintprimarykeynotnull
identity(1,1),unamevarchar(20),uageint);
createtabletest3_bak(idintprimarykeynot
nullidentity(1,1),bidint,unamevarchar(20),
uageint,activechar(1));
第二步,编写备份用的触发器,只要更新大概是拔出的时分才触发
以下是援用片断为例:
altertriggertest3_bak_insert_update
ontest3
forinsert,update
as
declare@idint
declare@unamevarchar(20)
declare@uageint
begin
select@id=id,@uname=uname,@uage=uagefrominserted
if@id0
begin
updatetest3_baksetactive=0wherebid=@id
insertintotest3_bak(bid,uname,uage,active)
values(@id,@uname,@uage,1)
end
end
第三步,测试数据:
上面是援用的片断为例:
insertintotest3(uname,uage)values(FLB,20)
insertintotest3(uname,uage)values(FLB1,21)
insertintotest3(uname,uage)values(FLB2,22)
updatetest3setuage=100whereid=27
deletefromtest3whereid=20
最初,你可本人接纳上面的查询踪两个表的数据变更:
以下是援用片断为例:
select*fromtest3
select*fromtest3_bak其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。 |
|