016_openxml_forxml
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的更多相关文章
随机推荐
- 常见的HTTPS攻击方法
0x00 背景 研究常见的https攻击方法 Beast crime breach,并针对https的特性提出一些安全部署https的建议. 针对于HTTPS的攻击,多存在于中间人攻击的环境中,主要是 ...
- 【Java】理解 UDDI 注册中心的 WSDL
如何发布和查找 WSDL 服务描述 Web 服务描述语言(WSDL)有多种用法.特别是,根据应用程序的需要,WSDL 在 UDDI 注册中心有好几种使用方法.在这第 1 篇文章中(本系列共三篇),我们 ...
- Unity3d 读取网络xml
Unity3d 读取网络xml Unity3d 读取网络xml,这个xml文件需要不包含BOM信息,可以用UltraEdit打开xml文件,并且另存为的时候,选择不包含BOM的utf-8格式存储!
- Sort it all out
poj1094:http://poj.org/problem?id=1094 题解(一位大神的分析) 一.当输入的字母全部都在前n个大写字母范围内时: (1)最终的图 可以排序: 在输入结束前如果能得 ...
- codeforces C. Prime Swaps
题意:给你n个数,然后在交换次数小于等于5×n的情况下使得这个序列变成升序,输出次数; 思路:哥德巴赫猜想:任何一个大于5的数都可以写成三个质数之和.尽可能的找大的素数,从1的位置向右逐步的调整,每一 ...
- I2C转UART
I2C转UART,51单片机普通IO口模拟I2C从机,解决UART不够的问题 /************************************************************ ...
- (转载)mysql查询今天、昨天、7天、近30天、本月、上一月数据
(转载)http://blog.163.com/dreamman_yx/blog/static/26526894201053115622827/ 查询 今天 select * from 表名 wher ...
- 【模拟】Codeforces 710C Magic Odd Square
题目链接: http://codeforces.com/problemset/problem/710/C 题目大意: 构造一个N*N的幻方.任意可行解. 幻方就是每一行,每一列,两条对角线的和都相等. ...
- sharepoint2007的中文版
今天终于下载到了sharepoint2007的中文版了,以前微软的测试板也没有中文版,今天终于下载到了,经过测试,用英文版的sn也是可以用的.微软提供的测试版,输入正式的key,就可以变成正式版了.我 ...
- 什么是左值(what is a lvalue)?
引用并翻译自<C++ premier plus> 左值是可以通过地址引用的数据对象(data object),例如,变量,数组的元素,结构体的成员,引用变量,以及复引用的指针(defere ...