sql对xml字段的操作

sql对xml字段的操作

ID:34726147

大小:67.68 KB

页数:4页

时间:2019-03-10

sql对xml字段的操作_第1页
sql对xml字段的操作_第2页
sql对xml字段的操作_第3页
sql对xml字段的操作_第4页
资源描述:

《sql对xml字段的操作》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、一、前言SQLServer2005引入了一种称为XML的本机数据类型。用户可以创建这样的表,它在关系列之外还有一个或多个XML类型的列;此外,还允许带有变量和参数。为了更好地支持XML模型特征(例如文档顺序和递归结构),XML值以内部格式存储为大型二进制对象(BLOB)。用户将一个XML数据存入数据库的时候,可以使用这个XML的字符串,SQLServer会自动的将这个字符串转化为XML类型,并存储到数据库中。随着SQLServer对XML字段的支持,相应的,T-SQL语句也提供了大量对XML操作的功能来配合SQLServer中XML字段的使用。本文主要说明如何

2、使用SQL语句对XML进行操作。二、定义XML字段在进行数据库的设计中,我们可以在表设计器中,很方便的将一个字段定义为XML类型。需要注意的是,XML字段不能用来作为主键或者索引键。同样,我们也可以使用SQL语句来创建使用XML字段的数据表,下面的语句创建一个名为“docs”的表,该表带有整型主键“pk”和非类型化的XML列“xCol”:CREATETABLEdocs(pkINTPRIMARYKEY,xColXMLnotnull)XML类型除了在表中使用,还可以在存储过程、事务、函数等中出现。下面我们来完成我们对XML操作的第一步,使用SQL语句定义一个XML

3、类型的数据,并为它赋值:定义XML类型数据declare@xmlDocxml;set@xmlDoc='CProgramDavid21'三、查询操作在定义了一个XML类型的数据之后,我们最常用的就是查询操作,下面我们来介绍如何使用SQL语句来进行查询操作的。在T-Sql中,提供了两个对XML类型数据进行查询的函数,分别是query(xquery)和value(xquery,dataType),其中,query(xquery)得

4、到的是带有标签的数据,而value(xquery,dataType)得到的则是标签的内容。接下类我们分别使用这两个函数来进行查询。1、使用query(xquery)查询我们需要得到书的标题(title),使用query(xquery)来进行查询,查询语句为:query()函数select@xmlDoc.query('/book/title')2、使用value(xquery,dataType)查询同样是得到书的标题,使用value函数,需要指明两个参数,一个为xquery,另一个为得到数据的类型。看下面的查询语句:value()函数select@xmlDoc.

5、value('(/book/title)[1]','nvarchar(max)')3、查询属性值无论是使用query还是value,都可以很容易的得到一个节点的某个属性值,例如,我们很希望得到book节点的id,我们这里使用value方法进行查询,语句为:查询属性select@xmlDoc.value('(/book/@id)[1]','nvarchar(max)')4、使用xpath进行查询xpath是.net平台下支持的,统一的Xml查询语句。使用XPath可以方便的得到想要的节点,而不用使用where语句。例如,我们在@xmlDoc中添加了另外一个节点,

6、重新定义如下:xpath查询set@xmlDoc='C#ProgramJerry50JavaProgramTom49'--得到id为0002的book节点select@xmlDoc.query('(/root/book[@id="0002"])')四、修改操作SQ

7、L的修改操作包括更新和删除。SQL提供了modify()方法,实现对Xml的修改操作。modify方法的参数为XML修改语言。XML修改语言类似于SQL的Insert、Delete、UpDate,但并不一样。例如,我们希望将id为0001的书的价钱(price)修改为100,我们就可以使用modify方法。代码如下:modify()修改节点值set@xmlDoc.modify('replacevalueof(/root/book[@id=0001]/price/text())[1]with"100"')--得到id为0001的book节点select@xmlD

8、oc.query('(/root/bo

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。