SQL Server 2005中XML操作函数详解

数据库 SQL Server 开发
本文中作者对SQL Server 2005中XML操作函数作了详细介绍,希望可以给你带来帮助。

首先要明确一个基本原则,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()

SELECT pk, xCol.query('/doc[@id = 123]//section')
FROM docs 

2.value()

SELECT xCol.value('data((/doc//section[@num = 3]/heading)[1])', 'nvarchar(max)')
FROM docs

3.exist()

SELECT xCol.query('/doc[@id = 123]//section')
FROM   docs
WHERE  xCol.exist ('/doc[@id = 123]') = 1

4.nodes()

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]')

--更改指定节点中的标量值('replace...with...')

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()方法:可以在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:column()方法:可以在XQuery或XML DML表达式中使用来自关系列的值。

【编辑推荐】

  1. 在ASP.NET中使用Treeview控件和XML
  2. 用XML和XSL来生成动态页面
  3. JavaScript解析XML的方法总结
责任编辑:杨鹏飞 来源: bugchen888的专栏
相关推荐

2009-04-02 09:46:19

排名函数排序SQL 2005

2010-07-19 11:17:28

SQL Server

2010-09-09 16:10:57

sql server2循环

2009-10-23 10:08:29

SQL SERVER

2009-10-23 12:44:35

SQL SERVER

2010-07-12 11:06:37

SQL Server2

2011-08-22 13:28:56

FOR XMLSQL Server

2010-10-21 15:13:20

SQL Server系

2010-03-19 10:23:06

2011-08-11 09:12:31

SQL Server nolock

2010-07-09 11:22:18

SQL Server

2010-07-23 12:55:29

SQL Server

2011-08-24 09:15:36

SQL Server数FOR XML AUT

2011-04-02 16:20:21

SQL SERVER 同步复制

2010-07-13 16:48:14

SQL Server

2011-09-01 16:13:37

Visual StudSQL Server 存储过程

2010-10-25 09:11:22

2010-09-08 14:03:41

SQL函数CONVERT

2013-03-01 11:27:27

SQL Server2SQL Server

2010-06-28 09:28:32

SQL Server
点赞
收藏

51CTO技术栈公众号