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

首先要清晰一个基本原则,XML类型的数据之间以及XML类型与其它数据类型之间都是不能比较的,也就是说XML类型的数据不能出现在等号的任何一边。

SQL Server 2005中XML操作函数详解(sql server xml解析)  XML 操作函数 2005 第1张

大致可分为查询类,修正类和跨域查询类。

查询类包括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的办法总结
转载请说明出处
知优网 » SQL Server 2005中XML操作函数详解(sql server xml解析)

发表评论

您需要后才能发表评论