XML,已成为近来最热门的Web技术,它是SQL Server 2000中的重要部分。本文将综合七条SQL Server 2000中最重要的XML综合特性组成XML之七种兵器。
兵器之一:FOR XML
在SQL Server 2000中,标准的T-SQL SELECT语句包括FOR XML子句,它以XML文档形式返回一个查询结果。新的FOR XML子句有三种模式——RAW,AUTO,和EXPLICIT,每个都能对XML文档格式提供附加标准的控制。
下面首先介绍“FOR XML”的使用方法。
为了从SQL Server提取XML格式的数据,T-SQL中加入了一个FOR XML命令。在查询命令中使用FOR XML命令使得查询结果以XML格式出现。FOR XML命令有三种模式:RAW,AUTO和EXPLICIT。图1所显示的SQL命令访问SQL Server提供的Pubs示例数据库。有关Pubs数据库的更多信息,请参见MSDN说明。如果我们依次指定该SQL命令的模式为三种允许的模式之一,就可以得到各种模式所支持的不同XML输出。
【图1 】
SELECT store.stor_id as Id, stor_name as Name,
sale.ord_num as OrderNo,sale.qty as Qty
FROM stores store inner join
sales sale on store.stor_id = sale.stor_id
ORDER BY stor_name
FOR XML <模式>
该查询命令所生成的结果包含所有销售记录及其对应的商店,结果以商店名称的字母升序排列。查询的最后加上了FOR XML命令以及具体的模式,比如FOR XML RAW。
理想情况下,SQL命令所生成的XML文档应具有如下结构:
<Stores>
<Store Id=&single;&single; Name=&single;&single;>
</Sale OrderNo=&single;&single; Qty=&single;&single;>
</Store>
</Stores>
下面我们来看看具体的处理方法。
RAW模式
下面是指定RAW模式时结果XML文档的一个片断。
查询结果集中每一个记录包含唯一的元素<row>。由于我们无法控制元素名字和文档结构,因此这种模式不是很有用。RAW模式所生成的文档结构与我们所希望的不符,而且它的用途也非常有限。
AUTO模式
下面是指定AUTO模式时结果文档的一个片断:
可以看到,<Stroe>和<Sale>两个元素是父-子关系,形成了我们所希望的层次结构。这种节点关系由查询中表的声明次序决定,后声明的表成为前声明表的孩子。
再参考图1,我们可以看出查询命令所指定的别名决定了XML文档中的名字。根据这一点,我们可以控制XML文档元素、属性的名字,使得这些名字符合我们所要求的命名惯例。
可见AUTO模式能够创建出我们所需要的XML文档。不过它存在以下缺点:
虽然可以得到层次结构,但这种层次结构是线性的,即每个父节点只能有一个子节点,反之亦然。
通过别名指定元素名字不太方便,而且有时候会影响查询命令本身的可读性。
无法在文档中同时生成元素和属性。要么全部是元素(通过ELEMENTS关键词指定),要么全部是属性(默认)。 EXPLICIT模式解决了上述不足。
[Access]sql随机抽取记录 [Access]ASP&SQL让select查询结果随机排序的实现方法 [互联动态]20008年最紧缺的IT人才和最热门七大技术 [聊天工具]Office 2000 服务器扩展 [聊天工具]最cool的p2p软件——edonkey2000 [聊天工具]企业邮件系统的利器----FoxMail Server [系统软件]八招秘籍保证Windows 2000安全 [系统软件]OPEN SERVER 5.0.5安装EXP300阵列柜 [系统软件]SQL语句性能优化--LECCO SQL Expert [系统软件]关于Windows2000Server的灾难恢复
|