FIX: 当您运行查询时对链接服务器的错误消息中创建 SQL Server 2005: [语句] 可能不准备就绪并且与表名称或别名在查询中使用的名称不匹配的列前缀 '<column_prefix_name>

文章翻译 文章翻译
文章编号: 936223 - 查看本文应用于的产品
错误 #: 50001186 (SQL 修补程序)
展开全部 | 关闭全部

本文内容

症状

请考虑以下情形。在 Microsoft SQL Server 2005 年,您可以通过使用 SQL 本机客户端 OLE DB 提供程序 (SQLNCLI) 创建链接的服务器。链接的服务器被链接到已安装的 Microsoft SQL Server 2000 的服务器。在这种情况下您将收到以下错误消息,当您对链接服务器中运行查询时:
错误消息 1
消息 8180,级别 16 状态 1,第 1 行
可能未准备的语句。
错误消息 2
消息 107,级别 16 状态 2,行 1
列前缀 ' <column_prefix_name> 与表名称或别名在查询中使用的名称不匹配。


注意SQL Server 2008 中也会出现此问题。如果您遇到此问题,当您连接到 SQL Server 2000 服务器 SQL Server 2008 中,您必须启用跟踪标记 4112 若要解决此问题。有关详细的信息,请参阅"更多信息"部分。

原因

因为 SQL Server 2005 生成具有远程查询执行计划,则会出现此问题。SQL Server 2005 必须执行远程查询 SQL Server 2000 检索所需的数据。SQL Server 2000 不能处理远程查询。因此,SQL Server 2000 中出现错误 107。然后,错误 107 被传播回 SQL Server 2005。因此,SQL Server 2005 中发生错误 107,并在 SQL Server 2005 年发生的错误 8180。

解决方案

累积更新信息

累积更新 2 中首先释放此问题的修复程序。有关如何获取 SQL Server 2005 Service Pack 2 的此累积更新包的详细信息单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
936305对于 SQL Server 2005 Service Pack 2 的累积更新包 2
注意因为这些版本是累积性的因此每个新的修补程序版本包含的所有修补程序和所有安全修补程序附带以前 SQL Server 2005 修补都程序版本。Microsoft 建议您考虑应用最新的修补程序版本包含此修补程序。有关详细的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
937137SQL Server 2005 生成发布 SQL Server 2005 Service Pack 2 之后发布的
为特定 SQL Server 服务包创建 Microsoft SQL Server 2005 修补程序。必须将 SQL Server 2005 Service Pack 2 修补程序应用到 SQL Server 2005 Service Pack 2 的安装。默认状态下,SQL Server service pack 中提供的任何修补程序包含在下一个 SQL Server 服务包中。

替代方法

要变通解决此问题,使用 Microsoft OLE DB 提供程序的 ODBC 创建 SQL Server 2000 对链接的服务器。

状态

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

更多信息

累积更新包 (生成 3175) SQL Server 2005 SP2 和 SQL Server 2008 同时引入了跟踪标志 4112。应用 SQL Server 2005 SP2 的累积更新包 (生成 3175) 后,您必须启用跟踪标记 4112 若要解决此问题。有关如何启用 SQL Server 2005 中的一个跟踪标志,请参阅下面的 Microsoft 开发人员网络 (MSDN) 的网站的"说明"部分:
http://msdn2.microsoft.com/en-us/library/ms188396.aspx

重现此问题的步骤

  1. 启动 SQL Server 管理 Studio,然后连接到 SQL Server 2005 实例。
  2. 创建一个新的查询,然后运行下面的语句。
    EXEC sp_addlinkedserver
    @server = '<LinkedServerName>', 
    @provider = 'SQLNCLI', 
    @srvproduct = '', 
    @datasrc = '<InstanceName>', 
    @catalog = '<DatabaseName>' 
    
    exec sp_serveroption
    @server = '<LinkedServerName>' 
    ,@optname = 'RPC' 
    ,@optvalue = 'TRUE'
    exec sp_serveroption
    @server = '<LinkedServerName>' 
    ,@optname = 'RPC OUT' 
    ,@optvalue = 'TRUE'
    
    
    DECLARE @supervisorID varchar(40)
    set @supervisorID = 'Volume Discount'
    
    SELECT DISTINCT J.STOR_ID
    FROM   [<LinkedServerName>].[<DatabaseName>].DBO.DISCOUNTS J
    WHERE  J.DISCOUNTTYPE = @supervisorID
           AND J.DISCOUNT = (SELECT MAX(B.DISCOUNT)
                             FROM   [<LinkedServerName>].<DatabaseName>.DBO.DISCOUNTS B
                             WHERE  B.DISCOUNTTYPE = J.DISCOUNTTYPE)
    
    GO
    
    笔记
    • <LinkedServerName>为链接服务器的名称的占位符。
    • <InstanceName>为链接服务器的实例名称的占位符。
    • <DatabaseName>为数据库名称的占位符。
运行这些语句后,您将收到"症状"部分中提到的错误消息。

属性

文章编号: 936223 - 最后修改: 2010年2月2日 - 修订: 2.0
这篇文章中的信息适用于:
  • Microsoft SQL Server 2005 Developer Edition
  • Microsoft SQL 2005 Server Enterprise
  • Microsoft SQL Server 2005 Standard Edition
  • Microsoft SQL Server 2005 Standard X64 Edition
  • Microsoft SQL Server 2005 Standard Edition for Itanium Based Systems
  • Microsoft SQL Server 2005 Enterprise X64 Edition
  • Microsoft SQL Server 2005 Enterprise Edition for Itanium Based Systems
  • Microsoft SQL Server 2008 Developer
  • Microsoft SQL Server 2008 Enterprise
  • Microsoft SQL Server 2008 Standard
  • Microsoft SQL Server 2008 Web
  • Microsoft SQL Server 2008 Workgroup
关键字:?
kbmt kbsql2005engine kbexpertiseadvanced kbfix kbpubtypekc kbqfe KB936223 KbMtzh
机器翻译
注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。
点击这里察看该文章的英文版: 936223
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