SQL Server XML转Table
前言
在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的更多相关文章
- SQL SERVER XML 学习总结
SQL SERVER XML 学习总结 最新的项目任务要做一个数据同步的功能,这些天都在做技术准备,主要是用到了微软的Service Broker技术,在熟悉使用该技术的同时,又用到了Sql s ...
- Sql Server xml 类型字段的增删改查
1.定义表结构 在MSSM中新建数据库表CommunicateItem,定义其中一个字段ItemContentXml 为xml类型 2.编辑表数据,新增一行,发现xml类型不能通过设计器录入数据. 需 ...
- 转载---SQL Server XML基础学习之<5>--XQuery(query)
本章写一些SQL Server XML的一些XQuery基础语法,主要讲的query查询语法 T-SQL 支持用于查询 XML 数据类型的 XQuery 语言的子集. XQuery 基于现有的 XPa ...
- SQL Server XML数据解析
--5.读取XML --下面为多种方法从XML中读取EMAIL DECLARE @x XML SELECT @x = ' <People> <dongsheng> <In ...
- SQL Server XML 查询
[参考1] 18个小实例入门SQLServer XML查询 [参考2] 转载---SQL Server XML基础学习之<5>--XQuery(query)
- SQL Convert XML to Table
将xml nodes 属性中的值 转为table 形式 declare @xml2 xml set @xml2 = '<CMADatas> <CMAData CmaName=&quo ...
- (轉載)sql server xml字段的操作
原文轉自:http://blog.csdn.net/hliq5399/article/details/8315373 另外可參考:https://msdn.microsoft.com/en-us/li ...
- SQL Server ->> XML方法
1. 得到XML类型中某个节点下子节点的数量 DECLARE @xml xml SET @xml = ' <Parameters> <Parameter name = "p ...
- sql server or Oracle: table MS_Description
--SQL Server表描述 及 字段描述的增.删.改.查询 --sql server 2000系统表sysproperties在SQL 2008中无效的问题 今天无意中在网上发现Sqlserver ...
随机推荐
- jQuery为哪般去掉了浏览器检测
由于做HTML5相关的项目,许多前卫时髦的前端技术就需要考虑一下IE是否支持.要是在以前,可以很方便地调用jQuery的jQuery.browser来实现. If(jQuery.browser.msi ...
- MVVM架构~knockoutjs系列之验证信息自定义输出~续
返回目录 上一讲中,我以一个实际中的例子说明了knockoutjs的自定义验证功能,在使用过程中,出现了一个问题,当然了不是问题,只是一种需求,上一讲中自定义验证的表现是:当页面加载后,自动显示有问题 ...
- Android 使用Font Awesome 显示文字图标
Android 使用Font Awesome 显示文字图标 简单几步就可以完成 简单的效果图: 1. 创建 assets 文件夹 在Android Studio 上的创建步骤为: 在 src/main ...
- Linux下chkconfig命令详解 这个简单明了啊
chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息.谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接. 使用语法:chkconfig [--ad ...
- WPF入门教程系列十——布局之Border与ViewBox(五)
九. Border Border 是一个装饰的控件,此控件绘制边框及背景,在 Border 中只能有一个子控件,若要显示多个子控件,需要将一个附加的 Panel 控件放置在父 Border 中.然后可 ...
- javascript_basic_03之函数、循环、数组
1.函数:函数(Function),方法(Method),过程(Procedure): 2.默认为假的情况: ①if(0){}:②if(0.0){}:③if(null){}:④if("&qu ...
- How Google TestsSoftware - Part One
This is the firstin a series of posts on this topic.The one question I get morethan any other is &qu ...
- java异常处理:建立exception包,建立Bank类,类中有变量double balance表示存款,Bank类的构造方法能增加存款,Bank类中有取款的发方法withDrawal(double dAmount),当取款的数额大于存款时,抛出InsufficientFundsException,取款数额为负数,抛出NagativeFundsException,如new Bank(100),
建立exception包,建立Bank类,类中有变量double balance表示存款,Bank类的构造方法能增加存款,Bank类中有取款的发方法withDrawal(double dAmount ...
- 练习2 练习目标-使用引用类型的成员变量:在本练习中,将扩展银行项目,添加一个(客户类)Customer类。Customer类将包含一个Account对象。
package banking; public class Customer { private String firstName; private String lastName; private ...
- 使用swoole和websocket结合来制造弹幕
在知乎上无意中看到了一篇有关这个的话题https://zhuanlan.zhihu.com/p/23992890,刚好没事也好久没弄swoole了就自己按照知乎上的那篇文站实操了一下 那个试验中有几个 ...