使用OPENXML函数将XML文档转换为行结果集
来源:互联网 发布:光翼网络班视频 编辑:程序博客网 时间:2024/05/17 21:42
FOR XML子句都是将行结果集转换为XML结果集,那么如果想要将XML文档转换成行结果集,这时就要使用OPENXML函数。OPENXML在SQL Server 2000中就已经提供,但是在SQL Server 2005对该函数进行了增强。
OPENXML的语法为:
运行的结果为:
FirstName MiddleName LastName
---------------- ---------------- ----------------
Gustavo NULL Achong
Catherine R. Abel
若将代码中OPENXML函数的第三个参数换为2那么将返回2行NULL值,因为2表示查询以元素为中心,而row节点下没有其他元素。同样的道理,如果给出的XML文档只有元素而没有属性,那么就要使用参数2而不能使用1 。那么如果想要查询出的数据一部分在元素的属性中,一部分在元素的子元素中那么我们可以将该参数换成3。查询语句及返回结果见代码:
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))
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>'
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等)就表示既要查询属性也要查询元素。
- 使用OPENXML函数将XML文档转换为行结果集
- 使用OPENXML函数将XML文档转换为行结果集
- 使用OPENXML函数将XML文档转换为行结果集
- 使用OPENXML函数将XML文档转换为行结果集
- 用OPENXML将XML数据转换为关联数据
- 将JDBC结果集转换为XML
- c#使用XSLT将xml文档转换为html文档
- 将XML字符串转换为XML文档
- [唐胡璐] - C#将QTP结果(XML+XSL文档)转换为HTML格式
- 使用OpenXml转换docx内容为RTF
- 使用javascript在客户端通过 XSLT 将 XML 文档转换为 XHTML,兼容IE和Firefox
- 将数据库中的记录转换为XML文档
- 将结果集Recordset信息格式化成XML文档
- 将xml类型转换为行形式
- 使用MSOffice .NET API 将文档(Word \ Excel \ PowerPoint \ Visio \ text \ XML \ RTF \ CSV等)转换为PDF
- 使用java将word文档转换为swf格式
- (二)使用JODConverter将office文档转换为pdf
- java使用openoffice将office系列文档转换为PDF
- 今天,很平常的一天,
- hadoop的负载均衡学习
- 数据挖掘-基于Kmeans算法、MBSAS算法及DBSCAN算法的newsgroup18828文本聚类器的JAVA实现(上)
- easyMock 使用总结
- c++:按逆序显示一个数
- 使用OPENXML函数将XML文档转换为行结果集
- 内存管理内幕动态分配的选择、折衷和实现
- Boost库学习
- 如何获取SQL Server数据库里表的占用容量大小
- LPC1768之串口UART0
- sql master数据库中两个非常有用的存储过程
- 数据结构和算法------简单排序
- error C2041: illegal digit '9' for base '8'
- 利用SQLiteOpenHelper来管理SQLite数据库