修复:"服务器: Msg 7359"错误时运行分布式的查询或 SQL Server 2008 R2 SQL Server 2008年中如果架构版本更新五倍以上

文章翻译 文章翻译
文章编号: 2588970 - 查看本文应用于的产品
展开全部 | 关闭全部

本文内容

Microsoft 将 Microsoft SQL Server 2008 Service Pack 2 (SP2) 修补程序分发作为一个可下载的文件。修补程序是累积性的因为每个新版本包含的所有修补程序和以前的 SQL Server 2008 SP2 中包含的所有安全更新来都更新发行版。

症状

请考虑以下情形:
  • Microsoft SQL Server 2008年或 Microsoft SQL Server 2008 R2 正在运行的计算机上创建链接的服务器。要在远程服务器上有一个 OLE DB 数据源的链接的服务器点。
  • 运行分布式的查询,使用链接服务器上的某些数据对象。
  • 您执行某些操作在远程服务器上,并操作导致的数据对象上的五个以上的架构版本更新。

    例如,您重建更新链接的服务器上的表的架构版本在远程服务器上的表的索引。

    注意 执行下一步执行查询之前的操作。
  • 再次运行该链接服务器上的分布式的查询。

在此方案中,不重新编译查询,并收到一条类似于以下的错误信息:
服务器: Msg 7359,级别 级别编号状态 状态号行号
OLE DB 提供程序"提供程序名称为链接的服务器""链接的服务器名称"报告编译时间 (之间的架构版本中的更改"编译时"),然后运行时间 ("运行时间") 为表"链接的表名称".
备注
  • 提供程序名称 是一个占位符的 OLE DB 提供程序的名称。
  • 链接的表名称 是查询链接服务器上的名称的占位符。
  • 下面的语句通常可以更改架构版本:
    • 变更表
    • 创建索引
    • 删除索引
    • DBCC 重新编制索引

原因

因为重新编译查询到期时,会出现此问题。

当架构进行更改时,缓存中的某些对象被删除,且查询所需的重新编译操作。但是,进行更新的架构版本的五个以上更改后达到上限值重新编译。因此,将出现"症状"部分中提到的问题。

解决方案

累积更新信息

SQL Server 2008 sp2 的累积更新包 6

此问题的修补程序是累积更新包 6 中首次推出。有关如何获取此累积更新包 SQL Server 2008 sp2 的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2582285 对于 SQL Server 2008 Service Pack 2 的累积更新包 6
注意 生成是累积性的因为每个新的更新版本包含的所有修补程序和以前的 SQL Server 2008 SP2 中包含的所有安全更新来都更新发行版。我们建议您考虑将应用最新的更新发行版包含此修复程序。有关详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
2402659 SQL Server 2008年生成发布 SQL Server 2008 SP2 后发布



替代方法

若要解决此问题,请使用下列方法之一:
  • 运行 DBCC FREEPROCCACHE(Plan_Handle) 语句。

    有关详细信息 Plan_Handle 参数,请访问下面的 MSDN 网站:
    Plan_Handle 参数有关的一般信息
  • 运行 sp_refreshView 'ViewName存储过程。

    注意 如果安装了累积更新包 3 SQL Server 2008 sp2,则此方法无法正常工作。

状态

Microsoft 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的一个问题。

属性

文章编号: 2588970 - 最后修改: 2011年9月19日 - 修订: 1.0
这篇文章中的信息适用于:
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Express
  • Microsoft SQL Server 2008 R2 Datacenter
  • Microsoft SQL Server 2008 R2 Developer
  • Microsoft SQL Server 2008 R2 Enterprise
  • Microsoft SQL Server 2008 R2 Express
  • Microsoft SQL Server 2008 R2 Express with Advanced Services
  • Microsoft SQL Server 2008 R2 Standard
  • Microsoft SQL Server 2008 R2 Workgroup
  • Microsoft SQL Server 2008 Service Pack 1
  • Microsoft SQL Server 2008 Service Pack 2
  • Microsoft SQL Server 2008 Standard
关键字:?
kbqfe kbfix kbexpertiseadvanced kbsurveynew kbmt KB2588970 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 2588970
Microsoft和/或其各供应商对于为任何目的而在本服务器上发布的文件及有关图形所含信息的适用性,不作任何声明。 所有该等文件及有关图形均"依样"提供,而不带任何性质的保证。Microsoft和/或其各供应商特此声明,对所有与该等信息有关的保证和条件不负任何责任,该等保证和条件包括关于适销性、符合特定用途、所有权和非侵权的所有默示保证和条件。在任何情况下,在由于使用或运行本服务器上的信息所引起的或与该等使用或运行有关的诉讼中,Microsoft和/或其各供应商就因丧失使用、数据或利润所导致的任何特别的、间接的、衍生性的损害或任何因使用而丧失所导致的之损害、数据或利润不负任何责任。

提供反馈

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com