使用OPENXML函数将XML文档转换为行结果集

本文介绍如何在 SQL Server 中利用 OPENXML 函数将 XML 文档转换为行结果集,包括不同参数设置的影响及其语法示例。
<script>function StorePage(){d=document;t=d.selection?(d.selection.type!='None'?d.selection.createRange().text:''):(d.getSelection?d.getSelection():'');void(keyit=window.open('http://www.365key.com/storeit.aspx?t='+escape(d.title)+'&u='+escape(d.location.href)+'&c='+escape(t),'keyit','scrollbars=no,width=475,height=575,left=75,top=20,status=no,resizable=yes'));keyit.focus();}</script>

FOR XML子句都是将行结果集转换为XML结果集,那么如果想要将XML文档转换成行结果集,这时就要使用OPENXML函数。OPENXML在SQL Server 2000中就已经提供,但是在SQL Server 2005对该函数进行了增强。
OPENXML的语法为:
运行的结果为:
FirstNameMiddleNameLastName
---------------- ---------------- ----------------
Gustavo NULLAchong
CatherineR. Abel
若将代码中OPENXML函数的第三个参数换为2那么将返回2行NULL值,因为2表示查询以元素为中心,而row节点下没有其他元素。同样的道理,如果给出的XML文档只有元素而没有属性,那么就要使用参数2而不能使用1 。那么如果想要查询出的数据一部分在元素的属性中,一部分在元素的子元素中那么我们可以将该参数换成3。查询语句及返回结果见代码:

OPENXML(idocint[in],rowpatternnvarchar[in],[flagsbyte[in]])
[WITH(SchemaDeclaration|TableName)]

第一个参数idoc是XML文档的句柄,该句柄需要通过调用 sp_xml_preparedocument 创建 XML 文档的内部表式形式来获得。参数rowpattern是一个XPATH模式,用来标识要作处理的节点。第三个参数中用1表示查询以属性为中心,2表示查询以元素为中心。最后WITH子句标识出要返回的字段。
使用OPENXML函数将该XML文档转换为行结果集的代码:

declare@mydocxml
set@mydoc='
<Person>
<rowFirstName="Gustavo"LastName="Achong"/>
<rowFirstName="Catherine"MiddleName="R."LastName="Abel"/>
</Person>
'--定义XML文档
declare@docHandleint
Execsp_xml_preparedocument@docHandleOUTPUT,@mydoc
--获得XML文档的句柄
SELECT*FROMOPENXML(@docHandle,'/Person/row',1)--1表示以属性为中心
WITH(FirstNamenvarchar(50),MiddleNamenvarchar(50),LastNamenvarchar(50))

declare@mydocxml
set@mydoc='
<Products>
<ProductCategory="Book">
<Name>Windows2008</Name>
<Vendor>Vendor1</Vendor>
</Product>
<ProductCategory="Book">
<Name>SQL2008</Name>
<Vendor>Vendor2</Vendor>
</Product>
</Products>
'
declare@docHandleint
Execsp_xml_preparedocument@docHandleOUTPUT,@mydoc
SELECT*FROMOPENXML(@docHandle,'/Products/Product',3)
WITH(Categorynvarchar(50),Namenvarchar(50),Vendornvarchar(50))

实际上第三个参数无论跟任何正整数SQL Server 2005都不会报错,微软官方MSDN中只给出了0、1、2、8这4个数字的意思。其实SQL Server 2005内部是根据第三个参数的二进制比特位上的值来确定查询的方式的。最后2位是00或01(比如:0、1、4、5等)就是以属性为中心进行查询,最后2为是10(比如:2、6、10等)就是以元素为中心的查询,而最后2位是11(比如:3、7等)就表示既要查询属性也要查询元素。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值