--定時同步服務器上的數據
--例子:
--測試環境,SQL Server2000,遠程服務器名:xz,用戶名為:sa,無密碼,測試數據庫:test
--服務器上的表(查詢分析器連接到服務器上創建)
create table [user](id int primary key,number varchar(4),name varchar(10))
go
--以下在局域網(本機操作)
--本機的表,state說明:null 表示新增記錄,1 表示修改過的記錄,0 表示無變化的記錄
if exists (select * from dbo.sysobjects where id = object_id(N'[user]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [user]
GO
create table [user](id int identity(1,1),number varchar(4),name varchar(10),state bit)
go
--創建觸發器,維護state字段的值
create trigger t_state on [user]
after update
as
update [user] set state=1
from [user] a join inserted b on a.id=b.id
where a.state is not null
go
--為了方便同步處理,創建鏈接服務器到要同步的服務器
--這里的遠程服務器名為:xz,用戶名為:sa,無密碼
if exists(select 1 from master..sysservers where srvname='srv_lnk')
exec sp_dropserver 'srv_lnk','droplogins'
go
exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','xz'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'sa'
go
--創建同步處理的存儲過程
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_synchro]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_synchro]
GO
create proc p_synchro
延伸閱讀
文章來源于領測軟件測試網 http://www.kjueaiud.com/