首页 > 数据库 > SQL Server > 正文

SQL SERVER Transactional Replication中添加新表如何不初始化整个快照

2024-08-31 00:54:51
字体:
来源:转载
供稿:网友
SQL SERVER Transactional Replication中添加新表如何不初始化整个快照 2015-02-02 00:29 by 潇湘隐者, ... 阅读, ... 评论, 收藏, 编辑

在SQL SERVER的复制(Replication)中,有可能出现由于业务需求变更,需要新增一张表或一些表到已有的复制(发布订阅)当中,这种需求应该是很正常,也很常见的。但是在已有的复制(发布订阅)当中增加新表/文章,往往需要将整个快照重新初始化,这样做虽然简单,但是往往在实际应用中会出现一些问题,例如,发布订阅的表比较多,数据量比较大,那么重新初始化快照往往需要很长一段时间,影响系统正常运行。另外就是这样做会增大服务器的负荷,影响网络带宽.

那么是否可以在新增表/文章后,不用初始化整个快照,而只是初始化新增的表呢? 当然可以,下面以一个小案例来讲述一下如何操作:

在数据库TTT上建立了名为RPL_TTT的发布,要发布的对象为WipNoToReed和WipNoToStarch这两张表,在另外一个服务器的数据库Test上订阅了该发布。现在由于需求变跟,需要增加一张表WipNoToLoosen

clipboard

我们可以按照下面三个步骤来操作,如下所示:

1:使用sp_helppublication查看该发布的相关信息,如下所示,你会看到默认情况下,'immediate_sync' 和 'allow_anonymous'这两个属性都是启用的。我们首先需要禁用这两个属性。

allow_anonymous 表示是否允许对发布使用匿名订阅。

immediate_sync 表示是否在每次快照代理运行时创建或重新创建同步文件。

use TTT;
go
sp_helppublication;
use TTT;
go
exec sp_helppublication 'RPL_TTT';

clipboard[1]

clipboard[2]

--Run on your publisher database
use TTT;
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表