通过备份初始化合并复制时的报错的解决

简介:
    由于关系数据库的机制要求合并复制数据同步时需要有良好的自治性,SQL Server的合并复制的应用场景相对比较少。一些典型的应用场景比如异地数据同步,跨洋的数据同步等。由于网络延时以及该种业务有相对比较大的数据独立性,因此在合并复制在某些场景会比较合适。

    在一些情况下,合并复制如果由于某些原因坏掉,需要重新初始化,而由于网络带宽的限制,用快照重新初始化稍微大一点的库基本不现实,因此需要考虑使用通过备份初始化,在初始化过程中,我遇到了如下错误:

 

{call sp_MSsetconflicttable (N'__UserSyncOptions', N'MSmerge_conflict_Main___UserSyncOptions', N'DB\MAIN', N'DB1', N'Main')}

Incorrect syntax near 'Id'.

 

    后来通过排查发现,疏忽了关键步骤,因此在此写下从备份初始化合并复制的正确姿势:

1.为需要合并复制的表添加唯一的RowGuid列,该列是合并复制用于确认行的唯一依据,因此该列有如下要求:

有唯一约束
有唯一索引
有GUID的默认值Newid()或newsequentialid()
该列Not Null
该列的添加脚本为:

BEGIN TRANSACTION
 
SET QUOTED_IDENTIFIER ON
 
SET ARITHABORT ON
 
SET NUMERIC_ROUNDABORT OFF
 
SET CONCAT_NULL_YIELDS_NULL ON
 
SET ANSI_NULLS ON
 
SET ANSI_PADDING ON
 
SET ANSI_WARNINGS ON
 
COMMIT
 
BEGIN TRANSACTION
 
GO
 
ALTER TABLE 表名称 ADD
 
ROWGUID uniqueidentifier NOT NULL ROWGUIDCOL CONSTRAINT MSmerge_df_rowguid_ DEFAULT (newid())
 
GO
 
ALTER TABLE 表名称 SET (LOCK_ESCALATION = TABLE)
 
GO
 
COMMIT

2. 备份需要初始化的数据库。 (在此期间,请不要备份日志,以防日志链断裂!)


3.  创建发布,并手动生成发布的快照。该步骤十分重要,虽然订阅服务器不需要快照初始化订阅,但是需要快照的元数据! 
  
4.  在订阅端还原数据库备份。注意,不能指定KEEP_REPLICATION选项。 
  
5.  创建订阅,选项请指定不立即初始化,如果是脚本创建订阅,请指定:@sync_type = N'None' 
  
6.  手动启动合并代理,以便从发布端同步元数据。至此整个过程完成。

分类: SQL Server Replication


本文转自CareySon博客园博客,原文链接:http://www.cnblogs.com/CareySon/p/4543938.html,如需转载请自行联系原作者
相关文章
|
8月前
|
Windows
FastCopy文件快速复制
FastCopy文件快速复制工具。Windows平台上最快的文件复制、删除软件!功能强劲,性能优越!它是源于日本的高效文件复制加速软件,支持拖拽操作,三种不同HDD模式;支持通配符,任务管理/命令行
51 0
|
8月前
|
关系型数据库 MySQL 测试技术
当update修改数据与原数据相同时会再次执行吗
当update修改数据与原数据相同时会再次执行吗
55 1
|
SQL 关系型数据库 MySQL
|
Linux
删除恢复的文件
当Linux计算机受到入侵时,常见的情况是日志文件被删除,以掩盖攻击者的踪迹。管理错误也可能导致意外删除重要的文件,比如在清理旧日志时,意外地删除了数据库的活动事务日志。有时可以通过lsof来恢复这些文件。
859 0
|
SQL 数据库
数据库页已标记为 RestorePending,可能表明磁盘已损坏。要从此状态恢复,请执行还原操作。
错误提示: 消息 829,级别 21,状态 1,第 1 行 数据库 ID 15,页 (1:21826) 已标记为 RestorePending,可能表明磁盘已损坏。要从此状态恢复,请执行还原操作。 引起原因: RestorePending一般是在进行页恢复的过程中出现的,就是在进行了restore操作之后但还没有进行recovery操作之前页的状态。
2532 0
Confluence 6 针对合并完全失败的内容重新运行合并
如果在系统合并的时候有任何内容的合并失败的话,一个 Confluence 的管理员可以再次重新启动内容合并(请参考前面页面的内容)。只有内容还是使用 wiki 格式的才会被合并,因此重新合并所需要的时间总是会少于原始内容合并所需要的时间的。
839 0
使用批处理复制并以时间规则重命名文件
原文:使用批处理复制并以时间规则重命名文件 @echo off::获取日期 将格式设置为:20110820set datevar=%date:~0,4%%date:~5,2%%date:~8,2%::获取时间中的小时 将格式设置为:24小时制set timevar=%time:~0,2%if /i ...
1709 0
|
存储 NoSQL Redis