--定时同步服务器上的数据
--例子:
--测试环境,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
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()   --执行数据处理的数据库名exec msdb..sp_add_jobstep @job_name='数据处理',
 @step_name = '数据同步',
 @subsystem = 'TSQL',
 @database_name=@dbname,
    @command = @sql,
 @retry_attempts = 5,   --重试次数
 @retry_interval = 5    --重试间隔--创建调度
EXEC msdb..sp_add_jobschedule @job_name = '数据处理', 
 @name = '时间安排',
 @freq_type = 4,     --每天
 @freq_interval = 1,    --每天执行一次
 @active_start_time = 00000  --0点执行
go

解决方案 »

  1.   

    http://blog.csdn.net/zjcxc/archive/2003/12/29/20082.aspx
      

  2.   

    异地数据库同步,走Internet么?
    广域网实现案例
    (1) 使用 Microsoft Proxy Server 通过 Internet 发布数据
    Microsoft® SQL Server™ 2000 复制与 Microsoft 代理服务器集成后,可通过 Internet,按照在 Microsoft Windows® NT 4.0 版或 Microsoft Windows 2000 Server 操作系统、Proxy Server 和 SQL Server 2000 上配置的安全性执行复制。通过该方法,Proxy Server 提供 Internet 与 SQL Server 2000 中存储数据的服务器的连接。订阅服务器通过 Internet 连接到 Proxy Server,并使用请求订阅接收数据。Proxy Server 在经过配置之后,未经授权的 Internet 用户不能访问内部网络资源,同时订阅服务器必须连接到 Proxy Server 上的某个端口,以限制它只能访问已授权的服务
    (2) 使用 TCP/IP 和 FTP 通过 Internet 发布数据
    Microsoft® SQL Server™ 2000 可以使用 TCP/IP 套接字或多协议 Net-Library 通过 TCP/IP 在发布服务器或分发服务器与订阅服务器之间建立 ODBC 连接。然后便可以配置发布和请求订阅或匿名订阅,访问含有要复制数据的 FTP 站点。配置应用程序可在 Internet 上发布数据要求: 
    • 配置侦听 TCP/IP的发布服务器或分发服务器
    • 配置发布以允许订阅使用 FTP 接收快照。
    • 创建订阅以使用 FTP 检索快照。
    • 配置订阅代理程序以使用 TCP/IP。
    (3) 使用 VPN 通过 Internet 发布数据
    虚拟专用网络 (VPN) 技术使用户得以在保持通讯安全的同时,在家中、分支机构、远程客户端和其它公司通过 Internet 连接到某公司网络进行工作。对于通过 Internet 发布数据,使用 VPN 是最安全的方法。用户可以象在局域网 (LAN) 上那样使用 Windows 身份验证。
    VPN 包括客户端软件,使得计算机可以通过 Internet(特殊情况下甚至是 Intranet)连接到专用计算机或服务器上的软件。用户可通过在两端加密和验证用户身份的办法来确保数据安全。通过 Internet 的 VPN 连接,其运作在逻辑上相当于站点间的广域网 (WAN) 链接。
    VPN 通过一个网络连接另一个网络的组件。其实现方法是允许用户以 Internet 或其它公共网络(使用诸如 Microsoft® Windows NT 4.0 版或 Microsoft Windows® 2000 操作系统中的 Microsoft 点对点隧道协议 (PPTP) 或者 Windows 2000 中的第 2 层隧道协议 (L2TP))为通道。这个过程提供了与以前专用网络相同的安全性和功能。
    对于用户来说,Internet 的中间路由基本结构是不可见的,数据好象通过专门的专用链接发送。用户所关心的是 VPN 是用户计算机和公司服务器之间的点对点连接。
    在将远程客户端配置为使用 VPN 进行连接,同时此客户端能访问 Internet 并已登录到公司 LAN 上之后,可以像此远程客户端直接处于 LAN 上一样地配置复制。出于安全性考虑,通过 VPN 连接的用户和直接地连接在局域网上的用户可能使用不同的网络资源。