SQL Server 中对XML数据的五种基本操作
来源:互联网 发布:樱井知香 下马番号 编辑:程序博客网 时间:2024/06/11 20:15
1.xml.exist
输入为XQuery表达式,返回0,1或是Null。0表示不存在,1表示存在,Null表示输入为空
2.xml.value
输入为XQuery表达式,返回一个SQL Server标量值
3.xml.query
输入为XQuery表达式,返回一个SQL Server XML类型流
4.xml.nodes
输入为XQuery表达式,返回一个XML格式文档的一列行集
5.xml.modify
使用XQuery表达式对XML的节点进行insert , update 和 delete 操作。
下面通过例子对上面的五种操作进行说明:
declare @XMLVar xml = '
<catalog>
<book category="ITPro">
<title>Windows Step By Step</title>
<author>Bill Zack</author>
<price>49.99</price>
</book>
<book category="Developer">
<title>Developing ADO .NET</title>
<author>Andrew Brust</author>
<price>39.93</price>
</book>
<book category="ITPro">
<title>Windows Cluster Server</title>
<author>Stephen Forte</author>
<price>59.99</price>
</book>
</catalog>'
1. xml.exist
select @XMLVar.exist('/catalog/book')-----返回1
select @XMLVar.exist('/catalog/book/@category')-----返回1
select @XMLVar.exist('/catalog/book1')-----返回0
set @XMLVar = null
select @XMLVar.exist('/catalog/book')-----返回null
2.xml.value
select @XMLVar.value('/catalog[1]/book[1]','varchar(MAX)')
select @XMLVar.value('/catalog[1]/book[2]/@category','varchar(MAX)')
select @XMLVar.value('/catalog[2]/book[1]','varchar(MAX)')
结果集为:
Windows Step By StepBill Zack49.99 Developer NULL
3.xml.query
select @XMLVar.query('/catalog[1]/book')
select @XMLVar.query('/catalog[1]/book[1]')
select @XMLVar.query('/catalog[1]/book[2]/author')
结果集分别为:
<book category="ITPro">
<title>Windows Step By Step</title>
<author>Bill Zack</author>
<price>49.99</price>
</book>
<book category="Developer">
<title>Developing ADO .NET</title>
<author>Andrew Brust</author>
<price>39.93</price>
</book>
<book category="ITPro">
<title>Windows Cluster Server</title>
<author>Stephen Forte</author>
<price>59.99</price>
</book>
<book category="ITPro">
<title>Windows Step By Step</title>
<author>Bill Zack</author>
<price>49.99</price>
</book>
<author>Andrew Brust</author>
4.xml.nodes
select T.c.query('.') as result from @XMLVar.nodes('/catalog/book') as T(c)
select T.c.query('title') as result from @XMLVar.nodes('/catalog/book') as T(c)
结果集分别为:
<book category="ITPro"><title>Windows Step By Step</title><author>Bill …………
<book category="Developer"><title>Developing ADO .NET</title><author>Andrew …………
<book category="ITPro"><title>Windows Cluster Server</title><author>Stephen …………
<title>Windows Step By Step</title>
<title>Developing ADO .NET</title>
<title>Windows Cluster Server</title>
5.xml.modify
关于modify内容,请参见
http://blog.csdn.net/tjvictor/archive/2009/07/21/4368496.aspx
如需转载,请注明本文原创自CSDN TJVictor专栏
http://blog.csdn.net/tjvictor/archive/2009/07/21/4368511.aspx
- SQL Server 中对XML数据的五种基本操作
- SQL Server 中对XML数据的五种基本操作
- SQL Server 中对XML数据的五种基本操作【转】
- SQL Server 中对XML数据的五种基本操作
- 对SQL Server 2005中XML操作函数的理解
- 对SQL Server 2005中XML操作函数的理解
- c#对sql server的基本操作
- Sql Server 对xml类型的操作
- SQL Server对Xml字段的操作
- SQL server对Xml字段的操作
- SQL Server对Xml字段的操作
- 对SQL Server 2005中XML操作函数
- C中对SQL Server的操作
- SQL 2005 对xml 文件与 xml数据的操作
- SQL 2005 对xml 文件与 xml数据的操作
- SQL 2005 对xml 文件与 xml数据的操作
- SQL server 2008 对XML 字段的操作
- SQL server语句对Xml字段的操作
- codeigniter 失误
- 快速排序
- 通过应用程序域AppDomain加载和卸载程序集
- iphone 下的 lighttpd 服务程序安装与卸载
- 操作系统还是有研究的必要---最近跟Java耗上了
- SQL Server 中对XML数据的五种基本操作
- 转:惠普前总裁孙振耀指点职业规划。(迄今见过的最好的职业规划的文章,毕生受益)!!!!
- Java中执行Shell(.sh)和windows批量处理(.bat)
- JAVA SE 相关
- 输了吧
- 优化iphone存储空间,以及优化iphone内存。
- 我学我体会(七)
- 实习后的第八天
- this作为对象的默认引用