详解SQL Server 2005 FOR XML嵌套查询的使用
http://www.itjxue.com 2015-07-17 09:23 来源:未知 点击次数:
相比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查询:
输出结果:
结果为字符串,只是内容格式符合Xml片段要求,不过无法在SQL Server Management Studio中点击以Xml方式显示。
下面对SQL进行修改,增加TYPE指令:
不出意外,查询结果收到如下错误提示:
不允许从数据类型xml 到nvarchar 的隐式转换。请使用CONVERT 函数来运行此查询。
可见通过TYPE指令返回的数据已经转变成Xml类型,改进后的查询语句如下:
通过SELECT 返回的结果支持Xml方式显示。