Microsoft 将 Microsoft SQL Server 2008 R2 Service Pack 1 修复分发为一个可下载文件。 由于修补程序是累积的,因此每个新版本都包含以前的 SQL Server 2008 R2 Service Pack 1 修复版本附带的所有修补程序和所有安全修补程序。
症状
请考虑以下情况:
-
在 Microsoft SQL Server 2008 R2 或 Microsoft SQL Server 2012 中的表中有一个 ntext 数据类型列。
-
创建一个事务复制,其中包含作为项目包含的表。
-
"Ntext 数据类型" 列将更新为 NULL。
在这种情况下,复制日志读取器代理将失败,并且你会收到以下错误消息:
错误:17066,严重性:16,状态:1。 SQL Server Assertion: File: <replicat>,line = 2701 失败断言 = "pRowset"。 此错误可能与计时有关。 如果再次运行该语句后,该错误仍然存在,请使用 DBCC CHECKDB 检查数据库的结构完整性,或者重新启动服务器以确保内存中的数据结构未损坏。
此外,当出现此问题时,日志读取器代理无法停止继续运行,并且每个后续日志读取器执行都会导致相同的错误。注意
-
当你使用 UPDATETEXT 语句更新 ntext 数据类型列时,此问题更为突出。
-
尽管在使用垂直筛选的 "项目" 列列表中排除了 ntext 数据类型列,但也会出现此问题。
解决方案
累积更新信息
SQL Server 2012 SP1 的累积更新2
此问题的修补程序首次在累积更新2中发布。有关如何获取此累积更新包的 SQL Server 2012 SP1 的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2790947 SQL Server 2012 的累积更新包 2 Service Pack 1注意 由于这些版本是累积的,因此每个新的修复版本都包含了以前的 SQL Server 2012 SP1 修补程序版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2772858 在发布 SQL Server 2012 Service Pack 1 之后发布的 SQL Server 2012 版本
SQL Server 2012 累积更新5
此问题的修补程序首次在累积更新5中发布。有关如何为 SQL Server 2012 获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2777772 SQL Server 2012 累积更新程序包5注意 由于这些版本是累积的,因此每个新的修复版本都包含以前的 SQL Server 2012 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2692828 在 SQL Server 2012 发布后发布的 SQL Server 2012 版本
SQL Server 2008 R2 SP2 的累积更新4
此问题的修补程序首次在累积更新4中发布。有关如何为 SQL Server 2008 R2 SP 2 获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2777358 SQL Server 2008 R2 Service Pack 2 的累积更新程序包4 注意 由于这些版本是累积的,因此每个新的修复版本都包含了以前的 SQL Server 2008 R2 SP 2 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2730301 发布 SQL Server 2008 R2 Service Pack 2 后发布的 SQL Server 2008 R2 版本
SQL Server 2008 R2 Service Pack 1
此问题的修补程序首次在 SQL Server 2008 R2 Service Pack 1 的累积更新9中发布。有关如何获取此累积更新包的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2756574 SQL Server 2008 R2 Service Pack 1 的累积更新包9注意 由于这些版本是累积的,因此每个新的修复版本都包含了以前的 SQL Server 2008 R2 Service Pack 1 修复版本附带的所有修补程序和所有安全修补程序。 我们建议你考虑应用包含此修补程序的最新修复版本。 有关更多信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2567616 在发布 SQL Server 2008 R2 Service Pack 1 之后发布的 SQL Server 2008 R2 版本若要解决此问题,请按照下列步骤操作:
-
除去受影响的数据库下的所有现有出版物。
-
应用修补程序。
-
从头开始重新创建发布或订阅。
状态
Microsoft 已确认这是在“适用范围”部分中列出的 Microsoft 产品存在的问题。
更多信息
有关 ntext、text 和 image 数据类型的详细信息,请转到以下 Microsoft 开发人员网络(MSDN)网站:
ntext、text 和 image (Transact-sql)有关复制类型的详细信息,请转到以下 MSDN 网站:
复制的类型概述有关事务性复制工作原理的详细信息,请转到以下 MSDN 网站: