一、前言

从 SQL Server 2005 开始,就增加了 xml 字段类型,也就是说可以直接把 xml 内容存储在该字段中,并且 SQL Server 会把它当作 xml 来对待,而不是当作 varchar 来对待。
随着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类型的数据,并为它赋值:
set @xmlDoc='<?xml version="1.0" ?>
<books>
<book id="0001">
<title>C Program</title>
<author>David</author>
<price>21</price>
</book>
<book id="0002">
<title>你必须知道的.NET</title>
<author>王涛</author>
<price>79</price>
</book>
</books>'
select @xmlDoc
三、XML字段注意点
三、XML字段注意点
四、查询操作
在定义了一个XML类型的数据之后,我们最常用的就是查询操作,下面我们来介绍如何使用SQL语句来进行查询操作的。
在T-Sql中,提供了两个对XML类型数据进行查询的函数,分别是query(xquery)和value(xquery, dataType),其中,query(xquery)得到的是带有标签的数据,而value(xquery, dataType)得到的则是标签的内容。接下类我们分别使用这两个函数来进行查询。
1、使用query(xquery) 查询
我们需要得到书的标题(title),使用query(xquery)来进行查询,查询语句为:
select @xmlDoc.query('(books/book/title)[1]')
运行结果如图:
2、使用value(xquery, dataType) 查询
同样是得到书的标题,使用value函数,需要指明两个参数,一个为xquery, 另一个为得到数据的类型。看下面的查询语句:
select @xmlDoc.value('(books/book/title)[1]', 'nvarchar(max)')
运行结果如图:
3、查询属性值
无论是使用query还是value,都可以很容易的得到一个节点的某个属性值,例如,我们很希望得到book节点的id,我们这里使用value方法进行查询,语句为:
select @xmlDoc.value('(books/book/@id)[1]', 'nvarchar(max)')
运行结果如图:
4、使用xpath进行查询
xpath是.net平台下支持的,统一的Xml查询语句。使用XPath可以方便的得到想要的节点,而不用使用where语句。例如,
--得到id为0002的book节点
select @xmlDoc.query('(/books/book[@id="0002"])')
上面的语句可以独立运行,它得到的是id为0002的节点。运行结果如下
五、修改操作
SQL的修改操作包括更新和删除。SQL提供了modify()方法,实现对Xml的修改操作。modify方法的参数为XML修改语言。XML修改语言类似于SQL 的Insert、Delete、UpDate,但并不一样。
1、修改节点值
我们希望将id为0001的书的价钱(price)修改为100, 我们就可以使用modify方法。代码如下:
set @xmlDoc.modify('replace value of (/books/book[@id=0001]/price/text())[1] with "100"')
--得到id为0001的book节点
select @xmlDoc.query('(/books/book[@id="0001"])')
注意:modify方法必须出现在set的后面。运行结果如图:
2、删除节点
接下来我们来删除id为0002的节点,代码如下:
--删除节点id为0002的book节点
set @xmlDoc.modify('delete /books/book[@id=0002]')
select @xmlDoc
运行结果如图:
3、添加节点
很多时候,我们还需要向xml里面添加节点,这个时候我们一样需要使用modify方法。下面我们就向id为0001的book节点中添加一个ISBN节点,代码如下:
--添加节点
set @xmlDoc.modify('insert <isbn>78-596-134</isbn> before (/books/book[@id=0001]/price)[1]')
select @xmlDoc.query('(/books/book[@id="0001"]/isbn)')
运行结果如图:
4、添加和删除属性
当你学会对节点的操作以后,你会发现,很多时候,我们需要对节点进行操作。这个时候我们依然使用modify方法,例如,向id为0001的book节点中添加一个date属性,用来存储出版时间。代码如下:
--添加属性
set @xmlDoc.modify('insert attribute date{"2008-11-27"} into (/books/book[@id=0001])[1]')
select @xmlDoc.query('(/books/book[@id="0001"])')
运行结果如图:
如果你想同时向一个节点添加多个属性,你可以使用一个属性的集合来实现,属性的集合可以写成:(attribute date{"2008-11-27"}, attribute year{"2008"}),你还可以添加更多。这里就不再举例了。
5、删除属性
删除一个属性,例如删除id为0001 的book节点的id属性,我们可以使用如下代码:
--删除属性
set @xmlDoc.modify('delete books/book[@id="0001"]/@id')
select @xmlDoc.query('(/books/book)[1]')
运行结果如图:
6、修改属性
修改属性值也是很常用的,例如把id为0001的book节点的id属性修改为0005,我们可以使用如下代码:
--修改属性
set @xmlDoc.modify('replace value of ( books/book[@id="0001"]/@id)[1] with "0005"')
select @xmlDoc.query('(/books/book)[1]')
运行结果如图:
经过上面的学习,相信你已经可以很好的在SQL中使用Xml类型了,下面是我们没有提到的:exist()方法,用来判断指定的节点是否存在,返回值为true或false; nodes()方法,用来把一组由一个查询返回的节点转换成一个类似于结果集的表中的一组记录行。 你可以去MSDN查阅 http://msdn.microsoft.com/zh-cn/library/ms190798.aspx。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# SQL2008
# 详解直接将XML存入到SQL中
# 直接将XML存入到SQL中详解
# 卸载SQL2008遇到问题(重启计算机失败、找不到SQL卸载程序)的解决办法
# sql2008安装教程 SQL Server 2008 R2 安装图解
# SQL2005、SQL2008允许远程连接的配置说明(附配置图)
# sql2008 hql语句翻译过来的分页语句介绍
# SQLServer日志清空语句(sql2000
# sql2005
# sql2008)
# SQL2008 附加数据库提示 5120错误 解决办法
# 使用Sqlserver事务发布实现数据同步(sql2008)
# sql2008评估期已过的解决办法及序列号
# sql2008安装后服务器改名造成名称不一致解决方法
# mssql2008 自定义表类型实现(批量插入或者修改)
# SQL2008 附加数据库提示5120错误解决方法
# 如图
# 的是
# 可以使用
# 你可以
# 这个时候
# 新和
# 类似于
# 以对
# 如何使用
# 主键
# 很好
# 还可以
# 多个
# 最多
# 则是
# 出现在
# 当你
# 你想
# 你还
# 把它
相关文章:
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
完全自定义免费建站平台:主题模板在线生成一站式服务
创业网站制作流程,创业网站可靠吗?
如何快速搭建高效可靠的建站解决方案?
TestNG的testng.xml配置文件怎么写
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
教程网站设计制作软件,怎么创建自己的一个网站?
如何高效搭建专业期货交易平台网站?
,石家庄四十八中学官网?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
北京营销型网站制作公司,可以用python做一个营销推广网站吗?
C++如何使用std::optional?(处理可选值)
建站之星微信建站一键生成小程序+多端营销系统
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
,制作一个手机app网站要多少钱?
西安专业网站制作公司有哪些,陕西省建行官方网站?
高端智能建站公司优选:品牌定制与SEO优化一站式服务
如何零基础在云服务器搭建WordPress站点?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
如何登录建站主机?访问步骤全解析
内网网站制作软件,内网的网站如何发布到外网?
如何在阿里云购买域名并搭建网站?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
已有域名和空间,如何快速搭建网站?
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
公司门户网站制作流程,华为官网怎么做?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
佛山企业网站制作公司有哪些,沟通100网上服务官网?
建站之星伪静态规则如何正确配置?
如何在Windows虚拟主机上快速搭建网站?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
怎么将XML数据可视化 D3.js加载XML
如何通过虚拟机搭建网站?详细步骤解析
历史网站制作软件,华为如何找回被删除的网站?
如何通过WDCP绑定主域名及创建子域名站点?
定制建站流程步骤详解:一站式方案设计与开发指南
香港网站服务器数量如何影响SEO优化效果?
实例解析Array和String方法
如何在IIS中配置站点IP、端口及主机头?
建站主机SSH密钥生成步骤及常见问题解答?
如何通过虚拟主机快速完成网站搭建?
建站之星多图banner生成与模板自定义指南
网站制作员失业,怎样查看自己网站的注册者?
如何在建站之星绑定自定义域名?
C#怎么使用委托和事件 C# delegate与event编程方法
c++怎么用jemalloc c++替换默认内存分配器【性能】
高性价比服务器租赁——企业级配置与24小时运维服务
如何快速重置建站主机并恢复默认配置?
用v-html解决Vue.js渲染中html标签不被解析的问题
网站好制作吗知乎,网站开发好学吗?有什么技巧?
*请认真填写需求信息,我们会在24小时内与您取得联系。