SQL Server 2005中XML操作函数开发方法
2011-06-24 20:32
435 查看
首先要明确一个基本原则,XML类型的数据之间以及XML类型与其它数据类型之间都是不能比较的,也就是说XML类型的数据不能出现在等号的任何一边。
大致可分为查询类,修改类和跨域查询类。
查询类包含query(),value(),exist()和nodes().
修改类包含modify().
跨域查询类包含sql:variable()和sql:column().
查询类
1. query()方法:返回满足条件的所有XML行。只能用于SELECT子句当中。
2. value()方法:返回从XML节点中提取的标量值。必须在value()方法的第二个参数中指定所返回的标量的数据类型,所以value()方法可以与其它标量进行比较。可用于SELECT子句和WHERE子句。
3. exist()方法:返回int型标量的0或者1。对每行的XML数据类型进行存在性检查。可用于SELECT子句和WHERE子句。
4. nodes()方法:返回只有一个栏位的table,且该table的栏位是XML数据类型。所以nodes()方法只能出现在FROM子句中。
示例:
1.query()
2.value()
3.exist()
4.nodes()
修改类IC报价网
modify()方法:允许修改XML实例的某些部分,例如添加或删除子树,或者更新标量值(如将书的价格从9.99替换为39.99)。
无返回值,只能用于SET子句中。
--在指定位置添加子树('insert...after...')
--更改指定节点中的标量值('replace...with...')
跨域查询类
如果数据驻留在关系数据类型的列和XML数据类型的列的组合中,就可能需要编写查询来组合关系数据处理和XML数据处理(组合的对象还可以是标量数据类型的SQL变量和XML数据),这样的查询就叫跨域查询。
sql:variable()方法:可以在IC报价网XQuery或XML DML表达式中应用SQL变量的值。
sql:variable()
sql:column()方法:可以在XQuery或XML DML表达式中使用来自关系列的值。
大致可分为查询类,修改类和跨域查询类。
查询类包含query(),value(),exist()和nodes().
修改类包含modify().
跨域查询类包含sql:variable()和sql:column().
查询类
1. query()方法:返回满足条件的所有XML行。只能用于SELECT子句当中。
2. value()方法:返回从XML节点中提取的标量值。必须在value()方法的第二个参数中指定所返回的标量的数据类型,所以value()方法可以与其它标量进行比较。可用于SELECT子句和WHERE子句。
3. exist()方法:返回int型标量的0或者1。对每行的XML数据类型进行存在性检查。可用于SELECT子句和WHERE子句。
4. nodes()方法:返回只有一个栏位的table,且该table的栏位是XML数据类型。所以nodes()方法只能出现在FROM子句中。
示例:
1.query()
SELECT pk, xCol.query('/doc[@id = 123]//section') FROM docs |
SELECT xCol.value('data((/doc//section[@num = 3]/heading)[1])', 'nvarchar(max)') FROM docs |
SELECT xCol.query('/doc[@id = 123]//section') FROM docs WHERE xCol.exist ('/doc[@id = 123]') = 1 |
SELECT nref.value('@genre', 'varchar(max)') LastName FROM docs CROSS APPLY xCol.nodes('//book') AS R(nref) |
modify()方法:允许修改XML实例的某些部分,例如添加或删除子树,或者更新标量值(如将书的价格从9.99替换为39.99)。
无返回值,只能用于SET子句中。
--在指定位置添加子树('insert...after...')
UPDATE docs SET xCol.modify(' insert <section num="2"> <heading>Background</heading> </section> after (/doc/section[@num=1])[1]') |
UPDATE XmlCatalog SET Document.modify (' default namespace = "http://myBooks" replace value of (/bookstore/book[@ISBN= "1-8610-0311-0"]/price)[1] with 49.99') |
如果数据驻留在关系数据类型的列和XML数据类型的列的组合中,就可能需要编写查询来组合关系数据处理和XML数据处理(组合的对象还可以是标量数据类型的SQL变量和XML数据),这样的查询就叫跨域查询。
sql:variable()方法:可以在IC报价网XQuery或XML DML表达式中应用SQL变量的值。
sql:variable()
DECLARE @isbn varchar(20) SET @isbn = '0-7356-1588-2' SELECT xCol FROM docs WHERE xCol.exist ('/book[@ISBN = sql:variable("@isbn")]') = 1 |
相关文章推荐
- 数据库开发基本操作-安装Sql Server 2005出现“性能监视器计数器要求”错误解决方法
- 数据库开发基本操作-SQL Server 2005 不允许远程连接解决方法
- 对SQL Server 2005中XML操作函数的理解
- SQL Server 2005中XML操作函数详解
- Visual C# 2008+SQL Server 2005 数据库与网络开发-- 4.5 操作视图
- SQL SERVER 2005中利用XML对字符串拆分的方法
- 数据库开发基本操作-关于sql server 2005 未开放1433端口的问题
- SQL Server 2005中三种插入XML数据的方法
- SQL Server 2005 XML 操作总结(三)元素(节点)操作——查询操作
- Visual C# 2008+SQL Server 2005 数据库与网络开发-- 10.6 XML和ADO .NET
- SQL Server 2005 XML 操作总结(三)元素(节点)操作——查询操作
- Visual C# 2008+SQL Server 2005 数据库与网络开发-- 11.5 LINQ To XML
- SQL Server 2005 XML 操作总结(四)元素(节点)操作——插入操作
- Visual C# 2008+SQL Server 2005 数据库与网络开发-- 10.7 在XML中串行化对象
- SQL Server 2005中xml类型和函数的简单应用
- SQL server 2005中新增的排序函数及操作
- SQL Server 2005 XML 操作总结(六)属性操作——查询操作
- SQL Server 2005 XML 操作总结(五)元素(节点)操作——修改、删除、移
- Visual C# 2008+SQL Server 2005 数据库与网络开发――3.2.3 扩展方法
- Visual C# 2008+SQL Server 2005 数据库与网络开发--第9章 SQL Server XML的功能