设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
查看: 2077|回复: 4
打印 上一主题 下一主题

利用SQL脚本完成数据库同步

[复制链接]
跳转到指定楼层
1#
发表于 2018-3-6 06:32:07 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
前段时间,需要处理数据库同步。由于之前切换服务器(额,那个locky……请自行百度),然后重装了系统,也不知道是因为权限问题还是端口的原因,反正后面试了好几次,发布订阅数据库都出错,于是只能退而求其次,打算用脚本来同步。

思路很简单,大体是先把原先存在的旧数据删除,再追加新数据。通过系统自带的计划任务,每天运行作业,从而达到同步的目的。需要解决的几个技术点分别是:

1、如何获取远程数据库。——链接服务器。大体是在管理工具/ODBC数据源上添加系统DSN,输入用户名,密码,服务器名称,数据库名,大体就好了。最后在服务器属性
2、要不要使用truncate。——如果存量数据较多(例如上千万条记录),建议不要使用truncate,而改用delete from where,毕竟插入1000万条记录,按SQL Server的性能,没一个小时大概是搞不定的(Sybase问题不大。而MySQL嘛,大概还要更慢,除非你优化得很好。)。
3、考虑到存量数据可能会更新,个人不建议使用insert into left join null方式来插入数据。
4、如何处理字段。——思路是有了,但总不能一个个字段手动敲进去吧?select 字段1,字段2……因此,可以考虑使用select distinct name from syscolumns where id =OBJECT_ID(表名称)来获取表字段,然后拼接为字符串。拼接的方法有两种,一个是用游标,另一个是用递归查询(从严格意义上说,这个其实算不上递归查询,因为没用CTE的特有表达式)。游标嘛,我试过,所以推荐用后者。
确定这几个问题之后,就可以写脚本了:
  1. create proc A9_Sametime(@tblName varchar(50),@dateFieldName varchar(50),@joinFieldName varchar(50)) AS
  2. declare @colname varchar(1800),
  3. @sqlDelOld varchar(8000),
  4. @sqlIndertNew varchar(8000),
  5. @startDate date,
  6. --长日期
  7. @startDateTime datetime,
  8. @endDateTime datetime
  9. set @startDate=GETDATE()
  10. --获取前一天数据
  11. set @startDateTime=DATEADD(day,-1,@startDate)
  12. set @endDateTime=DATEADD(MILLISECOND,-3,convert(datetime,@startdate))
  13. set @colname=''
  14. --递归查询,获取所有字段
  15. select @colname=@colname+c.name+ ',' from (select distinct name from syscolumns where id =OBJECT_ID(@tblName) ) c
  16. set @colname=substring(@colname,1,len(@colname)-1)
  17. --使用临时表(逗你玩的,渣渣的临时表)
  18. /*
  19. set  @sql='select * into #temp'
  20.                         +@colname+' from openquery(A9Server,'+'''select '+@colname
  21.                         +' from [A9SERVER].[S60623].[dbo].['+@tblName+']'
  22.                         +' where '+@dateFieldName+' between '''''
  23.                         +convert(varchar(23),@startDateTime,21)
  24.                         +''''' and '''''+convert(varchar(23),@endDateTime,21)+''''';'') '
  25. */
  26. --使用链接服务器,完成数据同步操作                       
  27. set @sqlDelOld='delete [A9].[dbo].['+@tblName+'] from'+
  28.                                         ' openquery(A9Server,'+'''select '+@colname
  29.                                         +' from [A9SERVER].[S60623].[dbo].['+@tblName+']'
  30.                                         +' where '+@dateFieldName+' between '''''
  31.                                         +convert(varchar(23),@startDateTime,21)
  32.                                         +''''' and '''''+convert(varchar(23),@endDateTime,21)+''''';'') A '
  33.                                         +' left join [A9].[dbo].['+@tblName+'] b'
  34.                                         +' on a.'+@joinFieldName+'=b.'+@joinFieldName

  35. set @sqlIndertNew='insert into [A9].[dbo].['+@tblName+']('+@colname+')  select '
  36.                                 +@colname+' from openquery(A9Server,'+'''select '+@colname
  37.                                 +' from [A9SERVER].[S60623].[dbo].['+@tblName+']'
  38.                                 +' where '+@dateFieldName+' between '''''
  39.                                 +convert(varchar(23),@startDateTime,21)
  40.                                 +''''' and '''''+convert(varchar(23),@endDateTime,21)+''''';'') '
  41. begin
  42.         exec(@sqlDelOld)
  43.         exec(@sqlIndertNew)
  44. end
复制代码
5、接下来创建作业,设置好计划任务属性(不是控制面板的那个哦)就好了。基本设置如下,并不复杂,所以这里就不全部贴图了。



本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

评分

参与人数 1经验 +30 收起 理由
admin + 30 (其它)优秀教程、原创内容、以资鼓励、其.

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏3 分享分享 分享淘帖 订阅订阅

点击这里给我发消息

2#
发表于 2018-3-6 07:05:02 | 只看该作者
强!坐个沙发!
3#
发表于 2018-3-7 03:28:45 | 只看该作者
借鉴下,有时间试试

点击这里给我发消息

4#
发表于 2019-2-21 19:56:33 | 只看该作者
厉害了我的哥,谢谢分享
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-4-19 19:50 , Processed in 0.080831 second(s), 29 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表