本文中作者对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)') |
3.exist()
SELECT xCol.query('/doc[@id = 123]//section') |
4.nodes()
SELECT nref.value('@genre', 'varchar(max)') LastName |
修正类
modify()办法:答应修正XML实例的某些部分,例如增加或删去子树,或许更新标量值(如将书的价格从9.99替换为39.99)。
无回来值,只能用于SET子句中。
--在指定方位增加子树('insert...after...')
UPDATE docs SET xCol.modify(' |
--更改指定节点中的标量值('replace...with...')
UPDATE XmlCatalog |
跨域查询类
假如数据驻留在联系数据类型的列和XML数据类型的列的组合中,就可能需求编写查询来组合联系数据处理和XML数据处理(组合的目标还能够是标量数据类型的SQL变量和XML数据),这样的查询就叫跨域查询。
sql:variable()办法:能够在XQuery或XML DML表达式中运用SQL变量的值。
sql:variable()
DECLARE @isbn varchar(20) |
sql:column()办法:能够在XQuery或XML DML表达式中运用来自联系列的值。
【修改引荐】
- 在ASP.NET中运用Treeview控件和XML
- 用XML和XSL来生成动态页面
- JavaScript解析XML的办法总结