sqlserverT-Sql操作Xml数据(一)

2014-11-24 15:32:53 · 作者: · 浏览: 1

一、前言

SQLServer 2005 引入了一种称为 XML 的本机数据类型。用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列;此外,还允许带有变量和参数。为了更好地支持 XML 模型特征(例如文档顺序和递归结构),XML 值以内部格式存储为大型二进制对象 (BLOB)。

用户将一个XML数据存入数据库的时候,可以使用这个XML的字符串,SQL Server会自动的将这个字符串转化为XML类型,并存储到数据库中。

随着SQL Server 对XML字段的支持,相应的,T-SQL语句也提供了大量对XML操作的功能来配合SQL Server中XML字段的使用。本文主要说明如何使用SQL语句对XML进行操作。

二、定义XML字段

在进行数据库的设计中,我们可以在表设计器中,很方便的将一个字段定义为XML类型。需要注意的是,XML字段不能用来作为主键或者索引键。同样,我们也可以使用SQL语句来创建使用XML字段的数据表,下面的语句创建一个名为“docs”的表,该表带有整型主键“pk”和非类型化的 XML 列“xCol”:

CREATE TABLE docs (pk INT PRIMARY KEY, xColXML not null)

XML类型除了在表中使用,还可以在存储过程、事务、函数等中出现。下面我们来完成我们对XML操作的第一步,使用SQL语句定义一个XML类型的数据,并为它赋值:

declare @xmlDoc xml;

set @xmlDoc='

C Program

David

21

'

三、查询操作

在定义了一个XML类型的数据之后,我们最常用的就是查询操作,下面我们来介绍如何使用SQL语句来进行查询操作的。

在T-Sql中,提供了两个对XML类型数据进行查询的函数,分别是query(xquery)和value(xquery,dataType),其中,query(xquery)得到的是带有标签的数据,而

value(xquery,dataType)得到的则是标签的内容。接下类我们分别使用这两个函数来进行查询。

1、使用query(xquery) 查询

我们需要得到书的标题(title),使用query(xquery)来进行查询,查询语句为:

declare @xmlDoc xml;

set @xmlDoc='

C#Program

Jerry

50

<a href="http://www.2cto.com/kf/ware/Java/" target="_blank" class="keylink">Java</a>Program

Tom

49

'

select @xmlDoc.query('/root/book/title')

select @xmlDoc.query('(//title)[2]')

select @xmlDoc.query('(root/book[1]/title)')

select @xmlDoc.query('(/root/book/title)[1]')

select @xmlDoc.query('/root/book[position()<2]/title')

declare @id varchar(max) = '0001'

select @xmlDoc.query('/root/book[@id=sql:variable("@id")]/title')

2、使用value(xquery, dataType) 查询

同样是得到书的标题,使用value函数,需要指明两个参数,一个为xquery,另一个为得到数据的类型。看下面的查询语句:

select @xmlDoc.value('(/root/book/title)[1]', 'nvarchar(max)')

select @xmlDoc.value('(/root/book[2]/title)[1]', 'nvarchar(max)')

select @xmlDoc.value('(//title)[1]', 'nvarchar(max)')

declare @id varchar(max) = '0002'

select @xmlDoc.value('(/root/book[@id=sql:variable("@id")]/title)[1]', 'nvarchar(max)')

3、查询属性值

无论是使用query还是value,都可以很容易的得到一个节点的某个属性值,例如,我们很希望得到book节点的id,我们这里使用value方法进行查询,语句为:

select @xmlDoc.value('(/root/book/@id)[1]', 'nvarchar(max)')

select @xmlDoc.value('(/root/book[2]/@id)[1]', 'nvarchar(max)')

四、修改操作

SQL的修改操作包括更新和删除。SQL提供了modify()方法,实现对Xml的修改操作。modify方法的参数为XML修改语言。XML修改语言类似于SQL 的Insert、Delete、UpDate,但并不一样。

1、修改节点值

代码如下:

select @xmlDoc.query('/root/book')

declare @id varchar(max) = '0001'

declare @price varchar(max) = '12345'

set @xmlDoc.modify('replace value of(/root/book[@id=sql:variable("@id")]/price/text())[1] with sql:variable("@price")')

select @xmlDoc.query('(/root/book[@id="0001"])')

set @xmlDoc.modify('replace value of(/root/book[@id="0002"]/price/text())[1] with 54321')

select @xmlDoc.query('(/root/book[@id="0002"])')

注意:modify方法必须出现在set的后面。

2、删除节点

代码如下:

select @xmlDoc.query('/root/book')

declare @id varchar(max) = '0001'

set @xmlDoc.modify('delete root/book[@id=sql:variable("@id")]')

select @xmlDoc.query('(/root/book)')

3、添加节点

代码如下:

select @xmlDoc.query('/root/book')

declare @id varchar(max) = '0001'

set @xmlDoc.modify('insert{sql:variable("@id")} before(/root/book[@id=0001]/price)[1]')

select @xmlDoc.query('(/root/book[@id="0001"])')

4、添加属性

代码如下:

--添加属性

set @xmlDoc.modify('insert attribute date{sql:variable("@id")} into (/root/book[@id=0001])[1]')

select @xmlDoc.query('(/root/book[@id="0001"])')

set @xmlDoc.modif