使用SQL Server触发器,同样可以对SQL数据库进行备份,下面就将为您介绍这种方法,希望对您学习使用SQL Server触发器能有所帮助。
首先,你需要建立测试数据表,一个用于插入数据: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)); 
 
第二步,编写备份用的SQL Server触发器,只有更新或者是插入的时候才触发
- alter trigger test3_bak_insert_update   
 - on test3   
 - for insert,update   
 - as   
 - declare @id int   
 - declare @uname varchar(20)   
 - declare @uage int   
 - begin   
 - select @idid=id,@unameuname=uname,@uageuage=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 
 
第三步,测试数据:
- 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 
 
最后,可采用下面的查询踪两个表的数据变化:
- select * from test3   
 - select * from test3_bak 
 
以上就是使用SQL Server触发器备份数据库的方法。
 
该文章在 2011/5/4 23:29:39 编辑过