收藏 分享(赏)

通过作业定时同步两个数据库.doc

上传人:gnk289057 文档编号:9502421 上传时间:2019-08-10 格式:DOC 页数:3 大小:30KB
下载 相关 举报
通过作业定时同步两个数据库.doc_第1页
第1页 / 共3页
通过作业定时同步两个数据库.doc_第2页
第2页 / 共3页
通过作业定时同步两个数据库.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

1、通过作业,定时同步两个数据库-定时同步服务器上的数据-例子:-测试环境,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_

2、id(Nuser) and OBJECTPROPERTY(id, NIsUserTable) = 1)drop table userGOcreate table user(id int identity(1,1),number varchar(4),name varchar(10),state bit)go-创建触发器,维护 state 字段的值create trigger t_state on userafter updateasupdate user set state=1from user a join inserted b on a.id=b.idwhere a.state is no

3、t nullgo-为了方便同步处理,创建链接服务器到要同步的服务器-这里的远程服务器名为:xz,用户名为:sa,无密码if exists(select 1 from mastersysservers where srvname=srv_lnk)exec sp_dropserver srv_lnk,droploginsgoexec sp_addlinkedserver srv_lnk,SQLOLEDB,xzexec sp_addlinkedsrvlogin srv_lnk,false,null,sago-创建同步处理的存储过程if exists (select * from dbo.sysobj

4、ects where id = object_id(Ndbo.p_synchro) and OBJECTPROPERTY(id, NIsProcedure) = 1)drop procedure dbo.p_synchroGOcreate proc p_synchroas-set XACT_ABORT on-启动远程服务器的 MSDTC 服务-exec masterxp_cmdshell isql /S“xz“ /U“sa“ /P“ /q“exec masterxp_cmdshell net start msdtc,no_output“,no_output-启动本机的 MSDTC 服务-exe

5、c masterxp_cmdshell net start msdtc,no_output-进行分布事务处理,如果表用标识列做主键,用下面的方法-BEGIN DISTRIBUTED TRANSACTION-同步删除的数据delete from srv_lnk.test.dbo.userwhere id not in(select id from user)-同步新增的数据insert into srv_lnk.test.dbo.userselect id,number,name from user where state is null-同步修改的数据update srv_lnk.test.d

6、bo.user setnumber=b.number,name=b.namefrom srv_lnk.test.dbo.user ajoin user b on a.id=b.idwhere b.state=1-同步后更新本机的标志update user set state=0 where isnull(state,1)=1-COMMIT TRANgo-创建作业,定时执行数据同步的存储过程if exists(SELECT 1 from msdbsysjobs where name=数据处理)EXECUTE msdb.dbo.sp_delete_job job_name=数据处理 exec ms

7、dbsp_add_job job_name=数据处理-创建作业步骤declare sql varchar(800),dbname varchar(250)select sql=exec p_synchro -数据处理的命令,dbname=db_name() -执行数据处理的数据库名exec msdbsp_add_jobstep job_name=数据处理,step_name = 数据同步,subsystem = TSQL,database_name=dbname,command = sql,retry_attempts = 5, -重试次数retry_interval = 5 -重试间隔-创建调度EXEC msdbsp_add_jobschedule job_name = 数据处理 , name = 时间安排 ,freq_type = 4, -每天freq_interval = 1, -每天执行一次active_start_time = 00000 -0 点执行go

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报