打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
用OPENXML函数将XML文件转换为行结果集
FOR XML子句都是将行结果集转换为XML结果集,那么如果想要将XML文件转换成行结果集,这时就要使用OPENXML函数。OPENXML在SQL Server 2000中就已提供,不过在SQL Server 2005对该函数进行了增强。

  OPENXML的语法为:

以下是引用片段:
  OPENXML( idoc int [ in] , rowpattern nvarchar [ in ] , [ flags byte [ in ] ] )
  [ WITH ( SchemaDeclaration | TableName ) ]

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

  使用OPENXML函数将该XML文件转换为行结果集的代码:

以下是引用片段:
declare @mydoc xml
set @mydoc=’
<Person>
  <row FirstName="Gustavo" LastName="Achong" />
  <row FirstName="Catherine" MiddleName="R." LastName="Abel" />
</Person>
’--定义XML文件
declare @docHandle int
Exec sp_xml_preparedocument @docHandle OUTPUT,@mydoc
--获得XML文件的句柄
SELECT * FROM OPENXML(@docHandle,’/Person/row’,1)--1表示以属性为中心
WITH (FirstName nvarchar(50),MiddleName nvarchar(50),LastName nvarchar(50))

  运行的结果为:

FirstName         MiddleName          LastName
----------------  ----------------    ----------------
Gustavo           NULL                Achong
Catherine         R.                  Abel

  若将代码中OPENXML函数的第三个参数换为2那么将返回2行NULL值,因为2表示查询以元素为中心,而row节点下没有其他元素。同样的道理,如果给出的XML文件只有元素而没有属性,那么就要使用参数2而不能使用1 。那么如果想要查询出的数据一部分在元素的属性中,一部分在元素的子元素中那么我们能将该参数换成3。查询语句及返回结果见代码:

以下是引用片段:
declare @mydoc xml
set @mydoc=’
<Products>
  <Product Category="Book">
    <Name>视窗系统 2008</Name>
    <Vendor>Vendor1</Vendor>
  </Product>
  <Product Category="Book">
    <Name>SQL2008</Name>
    <Vendor>Vendor2</Vendor>
  </Product>
</Products>’
declare @docHandle int
Exec sp_xml_preparedocument @docHandle OUTPUT,@mydoc
SELECT * FROM OPENXML(@docHandle,’/Products/Product’,3)
WITH (Category nvarchar(50),Name nvarchar(50),Vendor nvarchar(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等)就表示既要查询属性也要查询元素。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
常见SQL Server导入导出数据的几个工具
SQL Server2005对XML的支持
使SQL Server数据支持 XML SQL server技术交流
【技术分享】Office文件格式基础知识(1)
OPENXML
XML数据类型的查询方法
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服