新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 软件开发 > 数据库 > sql server教程 > 正文:巧用触发器对“SQL Server“进行数据备份

巧用触发器对“SQL Server“进行数据备份

新客网 XKER.COM 2008-02-03 来源:赛迪网 韩丹 收藏本文

本文中,笔者主要讲解了如何使用触发器来对SQL Server进行数据备份,具体内容请大家参考下文:

1、建立测试数据表:

第一个用于插入数据:test3

另外一个作为备份:test3_bak

以下是的引用片段:

create table test3(id int primary key not null 
identity(1,1),uname varchar(20),uage int); 
create table test3_bak(id int primary key not 
null identity(1,1),bid int,uname varchar(20), 
uage int,active char(1));

2、编写备份用的触发器,只有更新或者是插入的时候才触发

以下是引用片段:

alter trigger test3_bak_insert_update 
on test3 
for insert,update 
as 
declare @id int 
declare @uname varchar(20) 
declare @uage int 
begin 
select @id=id,@uname=uname,@uage=uage from inserted 
if @id<>0 
begin 
update test3_bak set active='0' where bid=@id 
insert into test3_bak(bid,uname,uage,active) 
values(@id,@uname,@uage,'1') 
end 
end

3、测试数据:

以下是引用的片段:

insert into test3(uname,uage) values('FLB',20) 
insert into test3(uname,uage) values('FLB1',21) 
insert into test3(uname,uage) values('FLB2',22) 
update test3 set uage=100 where id=27 
delete from test3 where id=20

4、大家可以采用下面的查询追踪两个表的数据变化:

以下是引用的片段:

select * from test3 
select * from test3_bak
收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐