查询类
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表达式中使用来自关系列的值。
一些例子:
---
create table #Test(xmlColumn xml)
go
insert #Test values('<book>
<b1 id="b001">aaaaa</b1>
<b2 id="b002">bbbbb</b2>
<b3 id="b003">ccccc</b3>
</book>')
go
select * from #Test
--更改b1节点的id属性
update #Test set xmlColumn.modify('replace value of (/book/b1/@id)[1] with "新的id"')
--为b1节点添加一个新的属性
update #Test set xmlColumn.modify('insert attribute price{"价格"} into (/book/b1)[1]')
go
select * from #Test
更多参考 http://msdn.microsoft.com/zh-cn/library/ms175466.aspx
包括SQl server xml列中:
A. 将元素节点插入文档中
B. 将多个元素插入文档中
C. 将属性插入文档中
D. 插入注释节点
E. 插入处理指令
F. 使用 CDATA 部分插入数据
G. 插入文本节点
H. 将新元素插入非类型化的 xml 列
I. 根据 if 条件语句进行插入
J. 将节点插入类型化的 xml 列中