详解SQL Server 2005 FOR XML嵌套查询的使用


 相比SQL Server 2000提供的FOR XML查询,SQL Server 2005版本对现有功能增强的基础上增加了不少新功能,最为吸引人的功能包括对Xml数据类型支持、使用PATH模式以及嵌套FOR XML查询支持等,这意味着通过新的FOR XML查询功能可以构造出结构更加灵活的Xml数据。

  在SQL Server 2000中FOR XML查询的结果是直接以文本方式返回到客户端,为支持SQL Server 2005中的Xml数据类型,FOR XML 查询提供了TYPE指令,通过TYPE支持返回结果将会变为Xml数据类型。接下来以SQL Server2005中的AdventureWorks示例数据库为例演练其功能。

  先来看第一个SQL查询:


  DECLARE @TestStringValue nvarchar(1024);
  SET @TestStringValue = (SELECT ProductID,[Name] FROM Production.Product
  WHERE ProductSubcategoryID = 9
  FOR XML AUTO);
  SELECT @TestStringValue;

  输出结果:

  结果为字符串,只是内容格式符合Xml片段要求,不过无法在SQL Server Management Studio中点击以Xml方式显示。

  下面对SQL进行修改,增加TYPE指令:


  DECLARE @TestStringValue nvarchar(1024);
  SET @TestStringValue = (SELECT ProductID,[Name] FROM Production.Product
  WHERE ProductSubcategoryID = 9
  FOR XML AUTO,TYPE);

  不出意外,查询结果收到如下错误提示:

  不允许从数据类型xml 到nvarchar 的隐式转换。请使用CONVERT 函数来运行此查询。

  可见通过TYPE指令返回的数据已经转变成Xml类型,改进后的查询语句如下:


  DECLARE @XmlTestValue xml;
  SET @XmlTestValue = (SELECT ProductID,[Name] FROM Production.Product
  WHERE ProductSubcategoryID = 9
  FOR XML AUTO,TYPE);
  SELECT @XmlTestValue;

  通过SELECT 返回的结果支持Xml方式显示。


« 
» 
快速导航

Copyright © 2016 phpStudy | 豫ICP备2021030365号-3