• 使用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>Windows 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等)就表示既要查询属性也要查询元素。

    【本文章出自博客园深蓝居,转载请注明作者出处,如果您觉得博主的文章对您有很大帮助,欢迎支付宝(studyzy@163.com)对博主进行打赏。】
  • 相关阅读:
    linux service 例子
    YII2自动初始化脚本
    ubuntu 如何在命令行打开当前目录
    mysql 储存过程
    Mysql 随笔记录
    Lack of free swap space on Zabbix server
    意外发现PHP另一个显示转换类型 binary
    常用的排序代码
    线程的实现方式之内核支持线程和用户级线程
    寻找二叉树中的最低公共祖先结点----LCA(Lowest Common Ancestor )问题(递归)
  • 原文地址:https://www.cnblogs.com/studyzy/p/988806.html
Copyright © 2020-2023  润新知