前言  

在SQL Server中有时候我们需要传人一个Table过去,然后可以在存储过程中批量更新,批量的获取相应数据。

但存储过程的参数是固定,所以这里我们可以变通的传人xml类型的参数,然后在存储过程中直接将其转换成我们需要的Table

具体实现

SQL Sever中已经支持XML类型的参数了,这里我们可以用OPENXML 方法来解析xml参数,OPENXML的MSDN。

OPENXML( idoc int [ in] , rowpattern nvarchar [ in ] , [ flags byte [ in ] ] )

以上可以看到OPENXML是三个参数:

第一个一般是通过存储过程sp_xml_preparedocument获取的。

第二个参数就是xpath

第三个参数标识符,1表示获取的是xml的属性,2表示获取xml的子节点。

下面我们demo一下flag为2的:

DECLARE @XML NVARCHAR(MAX);
SET @XML = '<airs>
<air>
<Dep>SYX</Dep>
<Arr>ZUH</Arr>
<AirCode>3U</AirCode>
<FlightNo>3U8432</FlightNo>
<Cabin>X</Cabin>
<DepDate>2016-07-06</DepDate>
</air>
<air>
<Dep>CGQ</Dep>
<Arr>CKG</Arr>
<AirCode>3U</AirCode>
<FlightNo>3U8864</FlightNo>
<Cabin>Y</Cabin>
<DepDate>2016-07-15</DepDate>
</air>
</airs>'; DECLARE @handle INT;
DECLARE @PrepareXmlStatus INT; EXEC @PrepareXmlStatus= sp_xml_preparedocument @handle OUTPUT, @XML; SELECT *
FROM OPENXML(@handle, '/airs/air', 2)
WITH (
Dep NVARCHAR(20),
Arr NVARCHAR(20),
AirCode NVARCHAR(20),
FlightNo NVARCHAR(20),
Cabin NVARCHAR(20),
DepDate DATE
); EXEC sp_xml_removedocument @handle;

其最终的结果:

Dep                  Arr                  AirCode              FlightNo             Cabin                DepDate
-------------------- -------------------- -------------------- -------------------- -------------------- ----------
SYX                  ZUH                  3U                   3U8432               X                    2016-07-06
CGQ                  CKG                  3U                   3U8864               Y                    2016-07-15

获取属性的demo如下:

DECLARE @XML XML;
SET @XML = '<airs>
<air Dep="SYX" Arr="ZUH" AirCode="3U" FlightNo="3U8432" Cabin="X" DepDate="2016-07-06" PrintPrice="1000"></air>
<air Dep="CGQ" Arr="CKG" AirCode="3U" FlightNo="3U8864" Cabin="Y" DepDate="2016-07-15" PrintPrice="1500"></air>
</airs>'; DECLARE @handle INT;
DECLARE @PrepareXmlStatus INT; EXEC @PrepareXmlStatus= sp_xml_preparedocument @handle OUTPUT, @XML; SELECT *
FROM OPENXML(@handle, '/airs/air', 1)
WITH (
Dep NVARCHAR(20),
Arr NVARCHAR(20),
AirCode NVARCHAR(20),
FlightNo NVARCHAR(20),
Cabin NVARCHAR(20),
DepDate DATE,
PrintPrice DECIMAL(18,2)
); EXEC sp_xml_removedocument @handle;

结果如下:

Dep                  Arr                  AirCode              FlightNo             Cabin                DepDate    PrintPrice
-------------------- -------------------- -------------------- -------------------- -------------------- ---------- ---------------------------------------
SYX                  ZUH                  3U                   3U8432               X                    2016-07-06 1000.00
CGQ                  CKG                  3U                   3U8864               Y                    2016-07-15 1500.00

总结

用OPENXML可以将xml转换为需要的TABLE,而且OPENXML的参数只有三个,大家多跑几次demo就可以了解了。

SQL Server XML转Table的更多相关文章

  1. SQL SERVER XML 学习总结

    SQL  SERVER  XML  学习总结 最新的项目任务要做一个数据同步的功能,这些天都在做技术准备,主要是用到了微软的Service Broker技术,在熟悉使用该技术的同时,又用到了Sql s ...

  2. Sql Server xml 类型字段的增删改查

    1.定义表结构 在MSSM中新建数据库表CommunicateItem,定义其中一个字段ItemContentXml 为xml类型 2.编辑表数据,新增一行,发现xml类型不能通过设计器录入数据. 需 ...

  3. 转载---SQL Server XML基础学习之<5>--XQuery(query)

    本章写一些SQL Server XML的一些XQuery基础语法,主要讲的query查询语法 T-SQL 支持用于查询 XML 数据类型的 XQuery 语言的子集. XQuery 基于现有的 XPa ...

  4. SQL Server XML数据解析

    --5.读取XML --下面为多种方法从XML中读取EMAIL DECLARE @x XML SELECT @x = ' <People> <dongsheng> <In ...

  5. SQL Server XML 查询

    [参考1] 18个小实例入门SQLServer XML查询 [参考2] 转载---SQL Server XML基础学习之<5>--XQuery(query)

  6. SQL Convert XML to Table

    将xml nodes 属性中的值 转为table 形式 declare @xml2 xml set @xml2 = '<CMADatas> <CMAData CmaName=&quo ...

  7. (轉載)sql server xml字段的操作

    原文轉自:http://blog.csdn.net/hliq5399/article/details/8315373 另外可參考:https://msdn.microsoft.com/en-us/li ...

  8. SQL Server ->> XML方法

    1. 得到XML类型中某个节点下子节点的数量 DECLARE @xml xml SET @xml = ' <Parameters> <Parameter name = "p ...

  9. sql server or Oracle: table MS_Description

    --SQL Server表描述 及 字段描述的增.删.改.查询 --sql server 2000系统表sysproperties在SQL 2008中无效的问题 今天无意中在网上发现Sqlserver ...

随机推荐

  1. Stealth视频教程学习笔记(第二章)

    Stealth视频教程学习笔记(第二章) 本文是对Unity官方视频教程Stealth的学习笔记.在此之前,本人整理了Stealth视频的英文字幕,并放到了优酷上.本文将分别对各个视频进行学习总结,提 ...

  2. 继电器是如何成为CPU的(2)

    继电器是如何成为CPU的(2) ——<穿越计算机的迷雾>整理和总结 上一篇已经从电池.开关.灯泡和继电器开始,画出了设计CPU所需的基本器件.这些器件将成为设计CPU的砖瓦木料.这一篇就用 ...

  3. IOS Animation-KeyPath值

    IOS Animation-KeyPath值 keyPath值 说明 值类型 position 移动位置 CGPoint opacity 透明度 0-1 bounds 变大与位置 CGRect bou ...

  4. 缓存篇(Cache)~第三回 HttpModule实现网页的文件级缓存

    返回目录 再写完缓存篇第一回之后,得到了很多朋友的好评和来信,所以,决定加快步伐,尽快把剩下的文章写完,本篇是第三回,主要介绍使用HttpModule实现的文件级缓存,在看本文之前,大家需要限度Htt ...

  5. CefSharp .net

    构建基于Chromium的应用程序 chromium是google chrome浏览器所采用的内核,最开始由苹果的webkit发展而出,由于webkit在发展上存在分歧,而google希望在开发上有更 ...

  6. Atitit 游戏的通常流程 attilax 总结 基于cocos2d api

    Atitit 游戏的通常流程 attilax 总结 基于cocos2d api 加载音效1 加载页面1 添加精灵1 设置随机位置2 移动2 垃圾gc2 点击evt2 爆炸效果3 定时生成精灵3 加载音 ...

  7. phpstudy80端口被占用时的解决方案

    1.适合人群? 之前笔记本单独安装过Apache.php.mysql环境,但是后期想用集成开发环境phpstudy的,安装完phpstudy后(之前的单独环境依然存在),发现启动时,总是显示80端口被 ...

  8. CCNA基础 IP地址子网划分

    计算机是一个非常神奇的物品,它的核心算法是凌驾于任何代码架构.然而互联网网络( Internat )作为整个生态的基础资源.什么?你还不会子网划分? 没关系,看到子网掩码不要怕.因为它无非就是问你 & ...

  9. javascript中的错误处理机制

    × 目录 [1]对象 [2]类型 [3]事件[4]throw[5]try[6]常见错误 前面的话 错误处理对于web应用程序开发至关重要,不能提前预测到可能发生的错误,不能提前采取恢复策略,可能导致较 ...

  10. struts深入理解之登录示例的源码跟踪

    废话不多,直接上图:(色泽比较重的是追踪的路径)