016_openxml_forxml

--openxml***********************************************************************

--将xml变量或者xml列的数据以表格显示

DECLARE @idoc int

DECLARE @doc nvarchar(max)

SET @doc =CONVERT(nVARCHAR(max),(SELECT tp.query('.') xml FROM test_xml WHERE id=N'4273465F-11DA-42C9-A457-E1ABAEE0CE58'))

--调用 sp_xml_preparedocument 以获得文档句柄。此文档句柄传递给 OPENXML

EXEC sp_xml_preparedocument @idoc OUTPUT, @doc

--1 使用“以属性为中心”的映射

SELECT *

FROM OPENXML(@idoc,'/bookstore/book/title',1)

WITH(lang NVARCHAR(100) '@lang',

category nvarchar(100) '../@category')

--2 使用“以元素为中心”的映射

SELECT *

FROM OPENXML (@idoc,'/bookstore/book',2)

WITH (title  varchar(10),

year varchar(20))

--移除句柄

EXEC sp_xml_removedocument @idoc

--for xml***********************************************************************

--将关系型表格数据以xml的形式来显示

--FOR XML PATH---------------------------------------

SELECT ParentObject,Object,Field,Value

FROM dbo.dbcc_page

FOR XML PATH,TYPE,ROOT('test')

--FOR XML EXPLICIT---------------------------------------

--创建test_explicit集合

WITH test_explicit

AS (

SELECT

1 tag,null parent,'white' [shark!1!name],NULL [fish!2!name],NULL [water!3!xian]

UNION ALL

SELECT 2,1,NULL,'liyu',NULL

UNION ALL

SELECT 3,2,NULL,NULL,'xian'

)

--查询集合,并用 EXPLICIT 格式显示

SELECT * from test_explicit FOR XML EXPLICIT

--1.查询样例

SELECT * FROM test_xml WHERE id=N'4273465F-11DA-42C9-A457-E1ABAEE0CE58' FOR XML PATH,ELEMENTS

--2.OPENXML 【在 XML 数据和关系行集间使用映射以及应如何填充溢出列】

/*

0  默认为“以属性为中心”的映射。

1  使用“以属性为中心”的映射。可以与 XML_ELEMENTS 一起使用。这种情况下,首先应用“以属性为中心”的映射,然后对所有未处理的列应用“以元素为中心”的映射。

2  使用“以元素为中心”的映射。可以与 XML_ATTRIBUTES 一起使用。这种情况下,首先应用“以属性为中心”的映射,然后对所有未处理的列应用“以元素为中心”的映射。

8  可与 XML_ATTRIBUTES 或 XML_ELEMENTS 组合使用(逻辑或)。在检索的上下文中,该标志指示不应将已使用的数据复制到溢出属性 @mp:xmltext。

*/

--3.for xml

/*

RAW  为 SELECT 语句所返回行集中的每行生成一个 <row> 元素。可以通过编写嵌套 FOR XML 查询来生成 XML 层次结构。

AUTO  基于指定 SELECT 语句的方式来使用试探性方法在 XML 结果中生成嵌套。

EXPLICIT 随意混合属性和元素来确定 XML 的形状

PATH  与嵌套 FOR XML 查询功能一起以较简单的方式提供了 EXPLICIT 模式的灵活性。

*/

--4. FOR XML EXPLICIT

/*

第一列必须提供当前元素的标记号(整数类型),并且列名必须是 Tag。查询必须为从行集构造的每个元素提供唯一标记号。

第二列必须提供父元素的标记号,并且此列的列名必须是 Parent。这样,Tag 和 Parent 列将提供层次结构信息。

*/

016_openxml_forxml的更多相关文章

随机推荐

  1. Zabbix的LLD功能--Low-level discovery

    感觉这个主题是和一个主题是一个系列,而且更基础. 准备深入研究一下... 相关文档准备: https://www.zabbix.com/documentation/2.0/manual/discove ...

  2. STM8S 模拟I2C程序

    STM8S的硬件I2C还是存在问题,不敢贸然使用. 于是决定用模拟I2C. #define SCL PE_ODR_ODR1 #define SDA PE_ODR_ODR2 #define SDAM P ...

  3. sudo and su

    sudo bash : change the current user into root su u1: change the current user into u1 useradd: add ne ...

  4. oracle触发器与:new,:old的使用 --5

    :new --为一个引用最新的列值;:old --为一个引用以前的列值; 这两个变量只有在使用了关键字 "FOR EACH ROW"时才存在.且update语句两个都有,而inse ...

  5. 【转】Android实例剖析笔记(二)--用实例讲解Andriod的开发过程,以NotesList为实例介绍Android的菜单机制

    原文网址:http://kb.cnblogs.com/page/78304/ 简介 android提供了三种菜单类型,分别为options menu,context menu,sub menu. op ...

  6. 动态规划(模型转换):uvaoj 1625 Color Length

    [PDF Link]题目点这里 这道题一眼就是动态规划,然而貌似并不好做. 如果不转换模型,状态是难以处理的. 巧妙地转化:不直接求一种字母头尾距离,而是拆开放到状态中. #include <i ...

  7. DFS Zoj 2110

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2110 //2110 #include<stdio.h> #in ...

  8. 考研路茫茫--单词情结 - HDU 2243(AC自动机+矩阵乘法)

    分析:与poj的2778差不多的,求出来所有的情况然后减去不包含的就行了,这次使用了一下kuangbin的那种自动机写法,确实还不错,因为尤是在建立矩阵的时候更加方便.   代码如下: ======= ...

  9. __block在ARC和非ARC下有什么不同

    一般在block中修改变量都需要事先加block进行修饰.在非arc中,block修饰的变量的引用计算是不变的.在arc中,会引用到,并且计算+1:非arc下可使用(arc直接使用__weak即可) ...

  10. web.xml基本配置描述

    先加载一段写好的web.xml: <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2. ...