Cnfan.net中国网络
IT网络技术专家
微软技术
 最新专题: Windows Server 2003 安全指南   IIS 技术专题   Exchange 2007 技术专题   SharePoint 2007 教程   跟我从头学WSH   专题 | 分类 | 投稿 | 搜索
 微软技术首页 | 微软动态 | Vista | Windows | ISA | Exchange | Share Point | SQL Server | System Center | 其它

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

  • 2008-02-15 22:57:39  作者:  来源:赛迪网  浏览次数:80  文字大小:【】【】【
简介: 本文中,笔者主要讲解了如何使用触发器来对SQL Server进行数据备份,详细内容请大家参考下文: 1、建立测试数据表: 第一个用于插入数据:test3 另外一个作为备份:test3_bak 以下是的引用 ...

关键字: SQL Server 数据库 备份还原 database

 

本文中,笔者主要讲解了如何使用触发器来对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

  <欢迎投稿>  <论坛讨论>
 »相关文章  »论坛新贴
精彩文章 活动资讯 今日头条