FIX: 一种使用 FOR XML AUTO 子句的查询将生成不同的结果在 SQL Server 2000 和 SQL Server 2005 中

注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。

点击这里察看该文章的英文版: 945901
错误: # 50001958 (SQL 修补程序)
Microsoft 将 Microsoft SQL Server 2005 修补程序分发作为一个可下载的文件。因为该修补程序是累积性的因此每个新版本包含的所有修补程序和所有安全修补程序附带以前 SQL Server 2005 修补都程序版本。
症状
您在运行 Microsoft SQL Server 2005 中使用 FOR XML AUTO 子句的查询时收到时 SQL Server 2000 中运行相同的查询的结果与不同结果。如果满足下列条件都为真,就会出现此问题:
  • 该查询的列上使用转换函数。
  • 转换功能在源列是与目的列中相同的。例如对于该查询使用下面的转换函数上的 日期时间 数据类型列:
    cast(ColumnA as datetime) as ColumnB
此外,如果将该实例的数据库兼容级别设置为 80,然后再运行该查询在再次结果是仍在 SQL Server 2000 结果不同。
原因
由于 SQL Server 2005 数据库引擎在同一个源列和目的列时,数据库引擎比较源列和目的列时忽略转换函数,则会发生此问题。但是,SQL Server 2000 数据库引擎未忽略转换函数。
解决方案
在累积更新 5 首先释放此问题的修复程序。有关如何获取 SQL Server 2005 Service Pack 2 的此累积更新包的详细信息单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
943656对于 SQL Server 2005 Service Pack 2 的累积更新包 5
注意因为这些版本是累积性的因此每个新的修补程序版本包含的所有修补程序和所有安全修补程序附带以前 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 已经确认这是在"适用于"一节中列出的 Microsoft 产品中的问题。
更多信息
应用此修补程序后,您将收到之间 SQL Server 2000 和 SQL Server 2005 一致的结果,该实例的数据库兼容级别设置为 80"症状"部分描述的方案中。

重现此问题的步骤

  1. 和 SQL Server 2000 实例上 SQL Server 2005 实例,请安装罗斯文示例数据库。
  2. 在这两个 SQL Server 的两个实例中运行以下查询:
    select top 1 t1.orderid ,t1.customerid ,t2.productid ,t1.shipregion ,cast(t2.unitPrice as money) unitPrice ,cast(t1.OrderDate as datetime) as OrderDate from orders t1 join [order Details] t2 on t1.orderid= t2.orderid where shipregion is not null for xml auto
在该实例的 SQL Server 2000,您会收到以下结果:
<t1 orderid="10283" customerid="LILAS" shipregion="Lara"> <t2 productid="15" unitPrice="12.4000" OrderDate="1996-08-16T00:00:00" /> </t1>
SQL Server 2005 实例,在您将收到以下结果:
<t1 orderid="10250" customerid="HANAR" shipregion="RJ" OrderDate="1996-07-08T00:00:00"> <t2 productid="41" unitPrice="7.7000" /> </t1>
有关哪些文件发生更改的详细信息,并应用累积更新包包含此 Microsoft 知识库文章中描述的修补程序的任何系统必备项有关的信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
943656对于 SQL Server 2005 Service Pack 2 的累积更新包 5
参考
有关列表后 SQL Server Service Pack 2 的可用版本的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
937137SQL Server 2005 生成发布 SQL Server 2005 Service Pack 2 之后发布的
对于 SQL Server 增量的服务模型的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
935897一个增量的服务模型是可从 SQL Server 团队提供报告的问题的修补程序
有关如何获取 SQL Server 2005 Service Pack 2 的详细信息单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
913089如何获取最新的 service pack,SQL Server 2005 年
有关新功能和 SQL Server 2005 Service Pack 2 中的改进的详细信息请访问下面的 Microsoft 网站:有关命名 SQL Server 更新架构的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
822499Microsoft SQL Server 软件更新程序包的新命名架构
有关软件更新术语的详细信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
824684用于描述 Microsoft 软件更新的标准术语的说明

警告:本文已自动翻译

属性

文章 ID:945901 - 上次审阅时间:01/03/2008 00:51:46 - 修订版本: 1.1

Microsoft SQL Server 2005 Standard Edition, Microsoft SQL Server 2005 Developer Edition, Microsoft SQL 2005 Server Enterprise, 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

  • kbmt kbsql2005engine kbhotfixrollup kbfix kbpubtypekc kbqfe kbexpertiseadvanced KB945901 KbMtzh
反馈