一个手工同步的方案

转载 2004年07月27日 12:58:00

--一个手工同步的方案

--定时同步服务器上的数据

--例子:
--测试环境,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

 

线上MYSQL同步报错故障处理总结

http://www.cnblogs.com/itcomputer/articles/5618907.html 前言 在发生故障切换后,经常遇到的问题就是同步报错,数据库很小的时候,d...
  • Steven_liwen
  • Steven_liwen
  • 2016-12-01 17:05:52
  • 3344

教你手工mysql拆库

教你手工mysql拆库  互联网网站应用大多采用mysql作为DB存储,限于mysql单机性能的瓶颈,为了支撑更大容量和更大的访问量,dba一般通过建立分布式集群,让多个mysql共同提...
  • zdy0_2004
  • zdy0_2004
  • 2015-01-27 21:28:13
  • 1291

线上MYSQL同步报错故障处理方法总结(必看篇)

前言在发生故障切换后,经常遇到的问题就是同步报错,数据库很小的时候,dump完再导入很简单就处理好了,但线上的数据库都150G-200G,如果用单纯的这种方法,成本太高,故经过一段时间的摸索,总结了几...
  • sj349781478
  • sj349781478
  • 2018-03-09 09:50:53
  • 28

mysql双机热备

MySQL双机热备 目录: 1、说明 2、数据手工同步 3、修改主数据库配置文件 4、修改从数据库配置文件 5、主数据库添加备份用户 6、从数据库设置为Slave 7、验证   1...
  • Loadrunn
  • Loadrunn
  • 2016-10-19 09:42:41
  • 428

一个手工同步的方案

--一个手工同步的方案 --定时同步服务器上的数据 --例子:--测试环境,SQL Server2000,远程服务器名:xz,用户名为:sa,无密码,测试数据库:test--服务器上的表(查询分析器连...
  • half_zhao
  • half_zhao
  • 2004-07-27 12:58:00
  • 470

Windows环境下,安装MySQL多实例,并实现Mysql的主从同步

一、 在同一台服务器上安装多个MariaDB实现一主多从(这里是伪从),即将多个从数据库同步到同一台服务器上,需要运行多个MySQL实例,如下文档。1.    官网下载Source源文件https:/...
  • u012843873
  • u012843873
  • 2017-10-18 16:55:43
  • 164

MySQL 同步(三)

 原贴:http://www.imysql.cn/node/56MySQL 同步(三) 周三, 2006/05/17 - 12:46 — yejr 6.5 不同MySQL版本之间的...
  • chinalinuxzend
  • chinalinuxzend
  • 2007-09-02 16:50:00
  • 869

Mysql事物处理

使用事物处理功能时,3个重要的命令BEGIN,COMMIT,ROLLBACK, 声明事物处理开始:BEGIN(START TRANSACTION); 提交事物:COMMIT; 回滚到事物开始的地...
  • zhangxiong0797
  • zhangxiong0797
  • 2014-03-10 23:53:59
  • 829

ORACLE进程无法KILL<em>处理</em>方案.docx

<em>手工</em>kill进程 立即下载 上传者: mesir 时间: 2007...oracle数据<em>同步</em>方案与实现.docx 立即下载 上传者: ...spring mvc+mybatis<em>+mysql+</em>maven+bootstrap 整合实现...
  • 2018年03月24日 00:00
收藏助手
不良信息举报
您举报文章:一个手工同步的方案
举报原因:
原因补充:

(最多只允许输入30个字)