我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)


一、在生产环境中已有事务复制中(复制类型为事务发布),需要对已有发布的数据库新增表、视图、存储过程等,这些变更是不会同步到从库中。如必须应用到从库,有以下两种方法:

1、如果采用默认的设置,每次都需要重新初始化快照,从库重新应用快照和未执行的同步命令,这在生产环境中对数据库压力或性能或DBA可维护性表现的很差。

2、将新增的架构变更新建一个新的发布订阅,但会造成维护困难,增加出错的几率。

3、可以通过设置immediate_sync和allow_anonymous 来实现不重新初始化快照的前提下,在原有的发布订阅中新增表/函数/存储过程。

   immediate_sync:指定每次运行快照代理时是否为发布创建同步文件。 

   immediate_synchronization的数据类型为 nvarchar(5),默认值为 FALSE。 如果为 True,表示每次运行快照代理时都创建或重新创建同步文件。 如果快照代理在订阅创建前完成,则订阅服务器可以立即获得同步文件。 新订阅将获取最近一次执行快照代理所生成的最新同步文件。 independent_agent 必须为 true,以便于 immediate_synchronization 为 true。 如果为 False,则仅当有新订阅时,才创建同步文件。 当以增量方式向现有发布添加新项目时,必须为每个订阅调用 sp_addsubscription。 订阅后订阅服务器无法接收同步文件,直到启动并完成快照代理为止。

    allow_anonymous:指定是否可为给定发布创建匿名订阅。 

    allow_anonymous的数据类型为nvarchar(5),默认值为 FALSE。如果为True,则immediate_synchronization 也必须设置为True。 如果为False,则表示不允许对该发布创建匿名订阅。

    ##注意:从定义中看出来,immediate_sync为false时,新的项目(表、存储过程等)可以以增量方式发布,而allow_anonymous也必须为false,immediate_sync才能为false。

    ##同时如果删除发布项目的中已发布的表/函数/存储过程/字段订阅库中的对应的表/函数/存储过程/字段仍然被保留,如要删除必须手工操作


二、根据以上定义进行测试

1、示例库为platform1126(发布数据库),订阅数据库为TDB1 

##注意:这里如何创建事务发布的复制操作(事务发布中的数据库所有表都需要主键列。),可以自行百度,或参考以下链接:http://blog.csdn.net/hliq5399/article/details/51678774   

2、创建事务发布发布名称为:pl_tdb,发布数据库上(platform1126)查看immediate_sync、allow_anonymous这两个属性当前默认属性。

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

USE platform1126
sp_helppublication;
或者:
select immediate_sync ,allow_anonymous from dbo .syspublications
查其默认结果为:
immediate_sync     allow_anonymous
1                  1
#修改immediate_sync、allow_anonymous参数为false或0:
use platform1126;
GO
EXEC sp_changepublication
@publication = 'pl_tdb', #publication为发布名称
@property = 'allow_anonymous',
@value = 'false'
GO
EXEC sp_changepublication
@publication = 'pl_tdb',
@property = 'immediate_sync' ,
@value = 'false'   
GO
#重新检查其设置结果
select immediate_sync ,allow_anonymous from dbo .syspublications
查其默认结果为:
immediate_sync    allow_anonymous
0                  0

3、在platform1126发布数据库中,重新添加新发布项目Advertise表

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

4、启动复制监视器,并启动快照代理,并查看详细


SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

5、查看订阅库TDB1,是否已经同步Advertise表

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)


##注:新增函数/存储过程类似如上操作,新增字段直接在发布库执行即可


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

目录