



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一、前言 SQL Server 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, xCol XML not null) XML类型除了在表中使用,还可以在存储过程、事务、函数等中出现。下面我们来完成我们对XML操作的第一步,使用SQL语句定义一个XML类型的数据,并为它赋值: 定义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)来进行查询,查询语句为:query()函数select xmlDoc.query(/book/title) 2、使用value(xquery, dataType) 查询同样是得到书的标题,使用value函数,需要指明两个参数,一个为xquery, 另一个为得到数据的类型。看下面的查询语句:value()函数select xmlDoc.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中添加了另外一个节点,重新定义如下:xpath查询set xmlDoc= C# Program Jerry 50 Java Program Tom 49 -得到id为0002的book节点select xmlDoc.query(/root/bookid=0002)四、修改操作 SQL的修改操作包括更新和删除。SQL提供了modify()方法,实现对Xml的修改操作。modify方法的参数为XML修改语言。XML修改语言类似于SQL 的Insert、Delete、UpDate,但并不一样。例如,我们希望将id为0001的书的价钱(price)修改为100, 我们就可以使用modify方法。代码如下:modify()修改节点值set xmlDoc.modify(replace value of (/root/bookid=0001/price/text()1 with 100)-得到id为0001的book节点select xmlDoc.query(/root/bookid=0001)注意:modify方法必须出现在set的后面。接下来我们来删除id为0002的节点,代码如下:删除节点-删除节点id为0002的book节点set xmlDoc.modify(delete /root/bookid=0002)select xmlDoc很多时候,我们还需要向xml里面添加节点,这个时候我们一样需要使用modify方法。下面我们就向id为0001的book节点中添加一个ISBN节点,代码如下:插入节点-添加节点set xmlDoc.modify(insert 78-596-134 before (/root/bookid=0001/price)1)select xmlDoc.query(/root/bookid=0001/isbn) 添加和删除属性:当你学会对节点的操作以后,你会发现,很多时候,我们需要对节点进行操作。这个时候我们依然使用modify方法,例如,向id为0001的book节点中添加一个date属性,用来存储出版时间。代码如下:添加属性-添加属性set xmlDoc.modify(insert attribute date2008-11-27 into (/root/bookid=0001)1)select xmlDoc.query(/root/bookid=0001)如果你想同时向一个节点添加多个属性,你可以使用一个属性的集合来实现,属性的集合可以写成:(attribute date2008-11-27, attribute year2008),你还可以添加更多。这里就不再举例了。 删除一个属性,例如删除id为0001 的book节点的id属性,我们可以使用如下代码:删除属性-删除属性set xmlDoc.modify(delete root/bookid=0001/id)select xmlDoc.query(/root/book)1)修改属性值也是很常用的,例如把id为0001的book节点的id属性修改为0005,我们可以使用如下代码:修改属性-修改属性set xmlDoc.modify(replace value of (root/bookid=0001/id)1 with 0005)select xmlDoc.query(/root/book)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 珍珠岩加工工理念考核试卷及答案
- 搪瓷窑炉司炉工安全规范考核试卷及答案
- 重冶浸出工入职考核试卷及答案
- 嗅辨员专业知识考核试卷及答案
- 水下钻井设备操作工标准化作业考核试卷及答案
- 工程机械装配调试工适应性考核试卷及答案
- 大数据应用重难点分析与解决措施
- 侍酒师职业考核试卷及答案
- 信息通信网络终端维修员设备维护与保养考核试卷及答案
- 医用设备安装验收后的服务措施
- 音乐ppt课件《村晚》
- 周绍华教授治疗抑郁症经验
- 分镜头脚本设计-影视广告分镜头课件
- 身体尺(课件)二年级上册数学人教版
- 欠款转为借款合同
- 公路隧道建设施工技术规范学习考试题库(400道)
- 新人教版七至九年级英语单词表 汉译英(含音标)
- 《儿童的语文》读书心得分享三2篇(一年级语文组)
- 人教版六年级语文上册生字表(带拼音词组)-2023修改整理
- 2023年山西日报社招聘笔试备考题库及答案解析
- 罐脚手架施工方案
评论
0/150
提交评论