设置合并发布的兼容级别

本主题说明如何使用 SQL Server Management Studio 或 Transact-SQL 在 SQL Server 2012 中设置合并发布的兼容级别。 合并复制使用发布兼容级别来确定给定数据库中的发布可以使用哪些功能。

本主题内容

  • 设置合并发布的兼容级别,使用:

    SQL Server Management Studio

    Transact-SQL

使用 SQL Server Management Studio

在新建发布向导的**“订阅服务器类型”页上设置兼容级别。 有关访问本向导的详细信息,请参阅创建发布。 创建了发布快照后,可以提高兼容级别但不能降低兼容级别。 在“发布属性 - <发布>”对话框的“常规”**页上可以提高兼容级别。 有关访问此对话框的详细信息,请参阅查看和修改发布属性。 如果要提高发布兼容级别,则运行该兼容级别的早期版本的服务器上的所有现有订阅都将不能同步。

注意注意

由于兼容级别具有其他发布属性的含义,并且项目属性对这些含义有效。因此,请不要使用同一个对话框更改兼容级别和其他属性。 应该在更改属性后重新生成发布的快照。

设置发布兼容级别

  • 在新建发布向导的**“订阅服务器类型”**页上,选择发布应支持的订阅服务器类型。

提高发布兼容级别

  • 在**“发布属性 - <发布>”对话框的“常规”页上,选择 SQL Server 2000SQL Server 2005 作为“兼容级别”**值。

用于“返回首页”链接的箭头图标[Top]

使用 Transact-SQL

可以在创建发布时以编程方式设置合并发布的兼容级别,或者以后以编程方式进行修改。 可使用复制存储过程来设置或更改此发布属性。

设置合并发布的发布兼容级别

更改合并发布的发布兼容级别

确定合并发布的发布兼容级别

  1. 执行 sp_helpmergepublication (Transact-SQL),同时指定所需的发布。

  2. 在结果集的 backward_comp_level 列中找到发布兼容级别。

示例 (Transact-SQL)

该示例创建合并发布并设置发布兼容级别。

-- To avoid storing the login and password in the script file, the values 
-- are passed into SQLCMD as scripting variables. For information about 
-- how to use scripting variables on the command line and in SQL Server
-- Management Studio, see the "Executing Replication Scripts" section in
-- the topic "Programming Replication Using System Stored Procedures".

--Add a new merge publication.
DECLARE @publicationDB AS sysname;
DECLARE @publication AS sysname;
DECLARE @login AS sysname;
DECLARE @password AS sysname;
SET @publicationDB = N'AdventureWorks2012'; 
SET @publication = N'AdvWorksSalesOrdersMerge' 
SET @login = $(Login);
SET @password = $(Password);

-- Create a new merge publication. 
USE [AdventureWorks2012]
EXEC sp_addmergepublication 
    @publication = @publication, 
    -- Set the compatibility level to SQL Server 2005.
    @publication_compatibility_level = '90RTM'; 

-- Create the snapshot job for the publication.
EXEC sp_addpublication_snapshot 
    @publication = @publication,
    @job_login = @login,
    @job_password = @password;
GO

该示例更改合并发布的发布兼容级别。

注意注意

如果发布使用任何要求采用特定兼容级别的功能,则可能不允许更改发布兼容级别。 有关详细信息,请参阅复制的向后兼容性

DECLARE @publication AS sysname
SET @publication = N'AdvWorksSalesOrdersMerge' 

-- Change the publication compatibility level to 
-- SQL Server 2012.
EXEC sp_changemergepublication 
    @publication = @publication, 
    @property = N'publication_compatibility_level', 
    @value = N'110RTM'
GO

该示例返回合并发布的当前发布兼容级别。

DECLARE @publication AS sysname
SET @publication = N'AdvWorksSalesOrdersMerge' 

EXEC sp_helpmergepublication 
    @publication = @publication;
GO

用于“返回首页”链接的箭头图标[Top]

请参阅

概念

创建发布