原文:SQLServer 以备份初始化订阅

在创建事务复制时,如果发布数据库很大,使用快照初始化时,将等待很久,如果出现问题可能又得重新初始化。使用备份初始化会省很多时间,但是数据库在创建发布订阅期间不能访问。使用备份代替快照迁移数据,备份可以压缩或使用 FTP 传输,若在同一个机房,拷贝复制更快。

现在测试:

创建测试库(发布服务器)

--	创建测试库(发布服务器)
USE [master]
GO
CREATE DATABASE [PubDB]
ON PRIMARY
(
NAME = N'PubDB',
FILENAME = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\PubDB.mdf' ,
SIZE = 5120KB ,
FILEGROWTH = 1024KB )
LOG ON
(
NAME = N'PubDB_log',
FILENAME = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\PubDB_log.ldf' ,
SIZE = 1024KB ,
FILEGROWTH = 10%)
GO -- 创建测试表(发布服务器)
USE [PubDB]
GO
CREATE TABLE [dbo].[PubTab](
[ID] [int] IDENTITY(1,1) NOT NULL,
[Name] [varchar](20) NOT NULL,
[Value] [decimal](18, 4) NULL,
CONSTRAINT [PK_PubTab] PRIMARY KEY CLUSTERED ([id] ASC),
) ON [PRIMARY]
GO INSERT INTO [dbo].[PubTab]([name],[Value])
VALUES('aa',99),('bb',100)
GO

添加复制用的登录账户和数据库用户。订阅不是同一个实例的添加登录账户(发布服务器/订阅服务器)

--	添加复制用的登录账户和数据库用户。订阅不是同一个实例的添加登录账户(发布服务器/订阅服务器)
USE [master]
GO
CREATE LOGIN [ReplUser] WITH PASSWORD=N'ReplUser', DEFAULT_DATABASE=[master], CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF
GO
ALTER SERVER ROLE [sysadmin] ADD MEMBER [ReplUser]
GO
USE [PubDB]
GO
CREATE USER [ReplUser] FOR LOGIN [ReplUser]
GO

创建发布(发布服务器)

创建完备份后,设置允许从备份文件初始化(发布服务器发布数据库)

--	允许从备份文件初始化(发布服务器发布数据库)
USE [PubDB]
GO
EXEC sp_changepublication
@publication = N'PublName',
@property = N'allow_initialize_from_backup',
@value = true
GO

备份数据库(发布服务器)

USE [master]
GO
BACKUP DATABASE [PubDB]
TO DISK = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\Backup\PubDB.bak'
WITH NOFORMAT, NOINIT, NAME = N'PubDB-完整 数据库 备份', SKIP, NOREWIND, NOUNLOAD, STATS = 10
GO

还原最新的备份数据库,将作为订阅库(订阅服务器)

USE [master]
GO
RESTORE DATABASE [SubDB]
FROM DISK = N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\Backup\PubDB.bak'
WITH FILE = 1,
MOVE N'PubDB' TO N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\SubDB.mdf',
MOVE N'PubDB_log' TO N'D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\DATA\SubDB_log.ldf',
NOUNLOAD, STATS = 5
GO

添加订阅,指定备份文件(发布服务器发布数据库)

USE [PubDB]
GO
EXEC sp_addsubscription
@publication = N'PublName',
@subscriber = N'HZC',
@destination_db = N'SubDB',
@subscription_type = N'Push',
@sync_type = N'initialize with backup',
@backupdevicetype='disk',
@backupdevicename='D:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLSERVER\MSSQL\Backup\PubDB.bak'



创建订阅后,更改订阅服务器连接账号

至此,发布订阅据配置完成了,现在看看表中的数据。

SELECT *  FROM [PubDB].[dbo].[PubTab]
SELECT * FROM [SubDB].[dbo].[PubTab]

增加一行记录再查看,复制正常!

INSERT INTO [PubDB].[dbo].[PubTab]([name],[Value]) VALUES('cc',0)
GO SELECT * FROM [PubDB].[dbo].[PubTab]
SELECT * FROM [SubDB].[dbo].[PubTab]

但是,当添加新表发布时,不能使用快照发布来同步了!~

创建测试表(发布服务器发布数据库),新表 identity 字段需要增加 NOT FOR REPLICATION

--	创建测试表(发布服务器发布数据库)
USE [PubDB]
GO
CREATE TABLE [dbo].[PubTab02](
[ID] [int] IDENTITY(1,1) NOT FOR REPLICATION NOT NULL,
[Name] [varchar](20) NOT NULL,
[Value] [decimal](18, 4) NULL,
CONSTRAINT [PK_PubTab02] PRIMARY KEY CLUSTERED ([id] ASC),
) ON [PRIMARY]
GO

正常的添加发布(发布服务器发布数据库)

这时不能启用快照同步了,快照没有用。

右键发布的表查看创建表的结构(发布服务器发布数据库),接着到订阅服务器数据库执行。

USE [SubDB]
GO
CREATE TABLE [dbo].[PubTab02](
[ID] [int] IDENTITY(1,1) NOT FOR REPLICATION NOT NULL,
[Name] [varchar](20) NOT NULL,
[Value] [decimal](18, 4) NULL,
CONSTRAINT [PK_PubTab02] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO

好了,添加算是完成了,现在测试添加数据(发布服务器发布数据库)

USE [PubDB]
GO
INSERT INTO [dbo].[PubTab02]([name],[Value]) VALUES('aa',99)
GO SELECT * FROM [PubDB].[dbo].[PubTab02]
SELECT * FROM [SubDB].[dbo].[PubTab02]

若是添加 / 删除 字段,按正常添加 / 删除即可,直接在发布服务器数据库执行,如。

USE [PubDB]
GO
ALTER TABLE [dbo].[PubTab02] ADD InsertDate DATETIME NULL
GO INSERT INTO [dbo].[PubTab02]([name],[Value],[InsertDate]) VALUES('aa',99,GETDATE())
GO SELECT * FROM [PubDB].[dbo].[PubTab02]
SELECT * FROM [SubDB].[dbo].[PubTab02]

参考:

初始化事务订阅(不使用快照)

SQL Server 通过备份文件初始化复制

SQLServer 以备份初始化订阅的更多相关文章

  1. Replication--使用备份初始化订阅--推送订阅

    1. 修改发布属性"许从备份文件初始化"置为TRUE2. 备份数据库并在订阅服务器上还原3. 创建订阅 -------------------------------------- ...

  2. Replication--使用备份初始化订阅--请求订阅

    1. 修改发布属性"许从备份文件初始化"置为TRUE 脚本修改:USE [DB01]GODECLARE @publication AS sysnameSET @publicatio ...

  3. SQLSERVER数据库备份操作和还原操作做了什么

    SQLSERVER数据库备份操作和还原操作做了什么 看了这篇文章:还原/备份时做了些什么 自己也测试了一下,下面说的错误日志指的是SQLSERVER ERRORLOG 一般在C:\Program Fi ...

  4. SQLServer 2008 R2 发布订阅配置指南

    原以为配置SQLServer 2008 R2的发布订阅很简单,实际配置后才发现过程中有问题地方一直都没搞明白,最后经过几天的查找问题和实践,终于搞定了.现将过程记录如下. SQLServer 2008 ...

  5. mysql 和 sqlserver中备份一张表的区别

    sqlserver中备份一张表 SELECT * into qa_buglist_bak FROM qa_buglist 不管表的数据有多大,速度很快: mysql中上述语句就无效了,须得新建一张表, ...

  6. 通俗易懂,C#如何安全、高效地玩转任何种类的内存之Span的脾气秉性(二)。 异步委托 微信小程序支付证书及SSL证书使用 SqlServer无备份下误删数据恢复 把list集合的内容写入到Xml中,通过XmlDocument方式写入Xml文件中 通过XDocument方式把List写入Xml文件

    通俗易懂,C#如何安全.高效地玩转任何种类的内存之Span的脾气秉性(二).   前言 读完上篇<通俗易懂,C#如何安全.高效地玩转任何种类的内存之Span的本质(一).>,相信大家对sp ...

  7. 将服务器上的SqlServer数据库备份到本地

    如何将服务器上的SqlServer数据库备份到本地电脑 http://bbs.csdn.net/topics/370051204 有A数据库服务器,B本机:    我现在想通过在B机器上通过代码调用S ...

  8. SqlServer & Windows 可更新订阅立即更新启用分布式事务协调器(MSDTC)

    原文:SqlServer & Windows 可更新订阅立即更新启用分布式事务协调器(MSDTC) 在可更新订阅中,在订阅设置更新方法,将 "排队更新" 设置为 " ...

  9. SQLSERVER 数据库备份脚本-支持多库备份

    原文:SQLSERVER 数据库备份脚本-支持多库备份 <pre name="code" class="sql">--变量定义 DECLARE @b ...

随机推荐

  1. PatentTips - Hardware virtualization such as separation kernel hypervisors

    BACKGROUND 1. Field Innovations herein pertain to computer virtualization, computer security and/or ...

  2. Javascript中的DOM实现显示鼠标的空间位置

    为了显示鼠标相对于浏览器的位置(相对于屏幕和页面类似),我们能够利用click事件,获得关于鼠标单击的事件对象event.这个事件对象里的clientX和clientY包括了鼠标的位置信息,所以我突发 ...

  3. Android在网络上分析获取图片(支持bmp格式)

    Android学习系列 - 在网络上显示的图像(支持bmp格公式)) 参见例如,下面的代码: /**     * 至Url地址上去照片.并返回Bitmap回来     *     * @param i ...

  4. matlab、sklearn 中的数据预处理

    数据预处理(normalize.scale) 0. 使用 PCA 降维 matlab: [coeff, score] = pca(A); reducedDimension = coeff(:,1:5) ...

  5. Xcode7.1 网络请求报错

    The resource could not be loaded because the App Transport Security policy reguir 原因:iOS9引入了新特性App T ...

  6. hdu 1418(抱歉)(欧拉公式,定点数,棱数,面数的关系)(水题)

    抱歉 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...

  7. WPF 中那些可跨线程访问的 DispatcherObject(WPF Free Threaded Dispatcher Object)

    原文 WPF 中那些可跨线程访问的 DispatcherObject(WPF Free Threaded Dispatcher Object) 众所周知的,WPF 中多数对象都继承自 Dispatch ...

  8. Cython 的学习

    开发效率极高的 Python 一直因执行效率过低为人所诟病,Cython 由此诞生,特性介于 Python 和 C 语言之间. Cython 学习 1. Cython 是什么? 它是一个用来快速生成 ...

  9. .NET/C# 使窗口永不激活(No Activate 永不获得焦点)

    原文 .NET/C# 使窗口永不激活(No Activate 永不获得焦点) 有些窗口天生就是为了辅助其它程序而使用的,典型的如“输入法窗口”.这些窗口不希望抢夺其它窗口的焦点. 有 Win32 方法 ...

  10. HTML 基础知识(特殊字符的转义)

    1. body.head(meta) <body></body>标签的常见属性: bgcolor:整个页面的背景: text:设置文本颜色 link:设置连接颜色(),vlin ...