as
--set XACT_ABORT on
--啟動遠程服務器的MSDTC服務
--exec master..xp_cmdshell 'isql /S"xz" /U"sa" /P"" /q"exec master..xp_cmdshell ''net start msdtc'',no_output"',no_output
--啟動本機的MSDTC服務
--exec master..xp_cmdshell 'net start msdtc',no_output
--進行分布事務處理,如果表用標識列做主鍵,用下面的方法
--BEGIN DISTRIBUTED TRANSACTION
--同步刪除的數據
delete from srv_lnk.test.dbo.[user]
where id not in(select id from [user])
--同步新增的數據
insert into srv_lnk.test.dbo.[user]
select id,number,name from [user] where state is null
--同步修改的數據
update srv_lnk.test.dbo.[user] set
number=b.number,name=b.name
from srv_lnk.test.dbo.[user] a
join [user] b on a.id=b.id
where b.state=1
--同步后更新本機的標志
update [user] set state=0 where isnull(state,1)=1
--COMMIT TRAN
go
--創建作業,定時執行數據同步的存儲過程
if exists(SELECT 1 from msdb..sysjobs where name='數據處理')
EXECUTE msdb.dbo.sp_delete_job @job_name='數據處理'
exec msdb..sp_add_job @job_name='數據處理'
--創建作業步驟
declare @sql varchar(800),@dbname varchar(250)
select @sql='exec p_synchro' --數據處理的命令
,@dbname=db_name() --執行數據處理的數據庫名
文章來源于領測軟件測試網 http://www.kjueaiud.com/