2000之七种兵器
来源:互联网 发布:350模板和淘宝什么区别 编辑:程序博客网 时间:2024/04/30 13:55
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
兵器之一:FORXML
在SQLServer2000中,标准的T-SQLSELECT语句包括FORXML子句,它以XML文档形式返回一个查询结果。新的FORXML子句有三种模式——RAW,AUTO,和EXPLICIT,每个都能对XML文档格式提供附加标准的控制。
下面首先介绍“FORXML”的使用方法。
为了从SQLServer提取XML格式的数据,T-SQL中加入了一个FORXML命令。在查询命令中使用FORXML命令使得查询结果以XML格式出现。FORXML命令有三种模式:RAW,AUTO和EXPLICIT。图1所显示的SQL命令访问SQLServer提供的Pubs示例。有关Pubs数据库的更多信息,请参见MSDN说明。如果我们依次指定该SQL命令的模式为三种允许的模式之一,就可以得到各种模式所支持的不同XML输出。
【图1】
SELECTstore.stor_idasId,stor_nameasName,
sale.ord_numasOrderNo,sale.qtyasQty
FROMstoresstoreinnerjoin
salessaleonstore.stor_id=sale.stor_id
ORDERBYstor_name
FORXML<模式>
该查询命令所生成的结果包含所有销售记录及其对应的商店,结果以商店名称的字母升序排列。查询的最后加上了FORXML命令以及具体的模式,比如FORXMLRAW。
理想情况下,SQL命令所生成的XML文档应具有如下结构:
<Stores>
<StoreId=&single;&single;Name=&single;&single;>
</SaleOrderNo=&single;&single;Qty=&single;&single;>
</Store>
</Stores>
下面我们来看看具体的处理方法。
RAW模式
下面是指定RAW模式时结果XML文档的一个片断。
查询结果集中每一个记录包含唯一的元素<row>。由于我们无法控制元素名字和文档结构,因此这种模式不是很有用。RAW模式所生成的文档结构与我们所希望的不符,而且它的用途也非常有限。
AUTO模式
下面是指定AUTO模式时结果文档的一个片断:
可以看到,<Stroe>和<Sale>两个元素是父-子关系,形成了我们所希望的层次结构。这种节点关系由查询中表的声明次序决定,后声明的表成为前声明表的孩子。
再参考图1,我们可以看出查询命令所指定的别名决定了XML文档中的名字。根据这一点,我们可以控制XML文档元素、属性的名字,使得这些名字符合我们所要求的命名惯例。
可见AUTO模式能够创建出我们所需要的XML文档。不过它存在以下缺点:
虽然可以得到层次结构,但这种层次结构是线性的,即每个父节点只能有一个子节点,反之亦然。
通过别名指定元素名字不太方便,而且有时候会影响查询命令本身的可读性。
无法在文档中同时生成元素和属性。要么全部是元素(通过ELEMENTS关键词指定),要么全部是属性(默认)。EXPLICIT模式解决了上述不足。
EXPLICIT模式
EXPLICIT模式比较复杂,我们将用另外一种方法来表达图1所显示的查询。这种方法使得我们能够完全地控制查询所生成的XML文档。首先我们将介绍如何改用EXPLICIT模式编写图1所显示的查询,然后看看这种方法如何赋予我们远远超过AUTO模式的能力。
下面是图1查询用EXPLICIT模式表达的代码:
【图2】
--商店数据
SELECT1asTag,
NULLasParent,
s.stor_idas[store!1!Id],
s.stor_nameas[store!1!Name],
NULLas[sale!2!OrderNo],
NULLas[sale!2!Qty]
FROMstoress
UNIONALL
--销售数据
SELECT2,1,
s.stor_id,
s.stor_name,
sa.ord_num,
sa.qty
FROMstoress,salessa
WHEREs.stor_id=sa.stor_id
ORDERBY[store!1!name]
FORXMLEXPLICIT
这个查询初看起来有点复杂,其实它只是把不同的数据集(即这里的Store和Sale)分解到了独立的SELECT语句里,然后再用UNIONALL操作符连结成一个查询。
我们之所以要把查询写成上面的形式,是为了让查询结果不仅包含XML文档所描述的数据,而且还包含描述XML文档结构的元数据。上述查询所生成的表称为Universal表,sqlxml.dll生成XML文档时需要这种格式。Universal表对于编写代码的人来说是透明的,但了解这个表还是很有意义的,它将有助于代码的开发和调试。下面是Universal表的一个例子:1
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 160x600, 创建于 08-4-23MSDN */google_ad_slot = "4367022601";google_ad_width = 160;google_ad_height = 600;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
XML,已成为近来最热门的Web技术,它是SQLServer2000中的重要部分。本文将综合七条SQLServer2000中最重要的XML综合特性组成XML之七种兵器。兵器之一:FORXML
在SQLServer2000中,标准的T-SQLSELECT语句包括FORXML子句,它以XML文档形式返回一个查询结果。新的FORXML子句有三种模式——RAW,AUTO,和EXPLICIT,每个都能对XML文档格式提供附加标准的控制。
下面首先介绍“FORXML”的使用方法。
为了从SQLServer提取XML格式的数据,T-SQL中加入了一个FORXML命令。在查询命令中使用FORXML命令使得查询结果以XML格式出现。FORXML命令有三种模式:RAW,AUTO和EXPLICIT。图1所显示的SQL命令访问SQLServer提供的Pubs示例。有关Pubs数据库的更多信息,请参见MSDN说明。如果我们依次指定该SQL命令的模式为三种允许的模式之一,就可以得到各种模式所支持的不同XML输出。
【图1】
SELECTstore.stor_idasId,stor_nameasName,
sale.ord_numasOrderNo,sale.qtyasQty
FROMstoresstoreinnerjoin
salessaleonstore.stor_id=sale.stor_id
ORDERBYstor_name
FORXML<模式>
该查询命令所生成的结果包含所有销售记录及其对应的商店,结果以商店名称的字母升序排列。查询的最后加上了FORXML命令以及具体的模式,比如FORXMLRAW。
理想情况下,SQL命令所生成的XML文档应具有如下结构:
<Stores>
<StoreId=&single;&single;Name=&single;&single;>
</SaleOrderNo=&single;&single;Qty=&single;&single;>
</Store>
</Stores>
下面我们来看看具体的处理方法。
RAW模式
下面是指定RAW模式时结果XML文档的一个片断。
查询结果集中每一个记录包含唯一的元素<row>。由于我们无法控制元素名字和文档结构,因此这种模式不是很有用。RAW模式所生成的文档结构与我们所希望的不符,而且它的用途也非常有限。
AUTO模式
下面是指定AUTO模式时结果文档的一个片断:
可以看到,<Stroe>和<Sale>两个元素是父-子关系,形成了我们所希望的层次结构。这种节点关系由查询中表的声明次序决定,后声明的表成为前声明表的孩子。
再参考图1,我们可以看出查询命令所指定的别名决定了XML文档中的名字。根据这一点,我们可以控制XML文档元素、属性的名字,使得这些名字符合我们所要求的命名惯例。
可见AUTO模式能够创建出我们所需要的XML文档。不过它存在以下缺点:
虽然可以得到层次结构,但这种层次结构是线性的,即每个父节点只能有一个子节点,反之亦然。
通过别名指定元素名字不太方便,而且有时候会影响查询命令本身的可读性。
无法在文档中同时生成元素和属性。要么全部是元素(通过ELEMENTS关键词指定),要么全部是属性(默认)。EXPLICIT模式解决了上述不足。
EXPLICIT模式
EXPLICIT模式比较复杂,我们将用另外一种方法来表达图1所显示的查询。这种方法使得我们能够完全地控制查询所生成的XML文档。首先我们将介绍如何改用EXPLICIT模式编写图1所显示的查询,然后看看这种方法如何赋予我们远远超过AUTO模式的能力。
下面是图1查询用EXPLICIT模式表达的代码:
【图2】
--商店数据
SELECT1asTag,
NULLasParent,
s.stor_idas[store!1!Id],
s.stor_nameas[store!1!Name],
NULLas[sale!2!OrderNo],
NULLas[sale!2!Qty]
FROMstoress
UNIONALL
--销售数据
SELECT2,1,
s.stor_id,
s.stor_name,
sa.ord_num,
sa.qty
FROMstoress,salessa
WHEREs.stor_id=sa.stor_id
ORDERBY[store!1!name]
FORXMLEXPLICIT
这个查询初看起来有点复杂,其实它只是把不同的数据集(即这里的Store和Sale)分解到了独立的SELECT语句里,然后再用UNIONALL操作符连结成一个查询。
我们之所以要把查询写成上面的形式,是为了让查询结果不仅包含XML文档所描述的数据,而且还包含描述XML文档结构的元数据。上述查询所生成的表称为Universal表,sqlxml.dll生成XML文档时需要这种格式。Universal表对于编写代码的人来说是透明的,但了解这个表还是很有意义的,它将有助于代码的开发和调试。下面是Universal表的一个例子:1
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 160x600, 创建于 08-4-23MSDN */google_ad_slot = "4367022601";google_ad_width = 160;google_ad_height = 600;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
- 2000之七种兵器
- [sql server] SQL Server 2000 XML之七种兵器
- 红客帝国之七种兵器
- 七种兵器
- 2007世界七种兵器排名
- 爱机使用保养七种兵器
- 心灵的七种兵器之三:内疚,和谐关系的调节者
- 站长的七件兵器
- ASP.NET状态存储管理九大兵器之七(其他物理数据存放媒体)
- 《士兵突击》之八件兵器
- Oracle兵器谱上古神器之-KFED
- 资深网管网络布线之常用兵器谱
- 乱谈编程语言---Lewolf之兵器谱
- 2009中文菜谱网站排行之十大兵器
- Web 开发与设计之 Google 兵器谱
- Web 开发与设计之 Google 兵器谱
- Web 开发与设计之 Google 兵器谱
- Web 开发与设计之 Google 兵器谱
- 通过存储过程进行字符串分拆,在同时删除多条记录的时候有用。
- Shipping Routes
- 一问一答:存储过程经典问题
- Pointbase学习
- 过程中一些命名规范
- 2000之七种兵器
- 访问程序包DBMS_APPLICATION_INFO时出错
- 本人用foxpro写的房屋产权产籍管理系统(未完)
- 在IE耗时操作中加入进度条或进度框
- WhatisIndex?索引是什么?
- 求记录中的最新数据的方法!
- 启动SQLServer的死锁检查
- ChangeAllObjectOwner
- VisualFoxpro中的多用户及数据缓冲问题