位置: 编程技术 - 正文

SQL2008 详解直接将XML存入到SQL中(sql server 2008怎么使用sql语句)

编辑:rootadmin

推荐整理分享SQL2008 详解直接将XML存入到SQL中(sql server 2008怎么使用sql语句),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql2008语句,sql2008语句,sql server 2008实例,sql直接join,sql server 2008实例,sql直接join,sql直接join,sql2008r2如何使用,内容如对您有帮助,希望把文章链接给更多的朋友!

一、前言

从 SQL Server 开始,就增加了 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”:

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

三、XML字段注意点

三、XML字段注意点

SQL Server 中以 Unicode(UTF-) 来存储 XML 数据。 XML 字段最多可存储 2G 的数据。 可以像插入字符串一样向 XML 字段写入内容。 当在 xml 数据类型实例中存储 XML 数据时,不会保留 XML 声明(如 <&#;xml version='1.0'&#;>)。 插入的 xml 内容的属性的顺序可能会与原 xml 实例的顺序变化。 不保留属性值前后的单引号和双引号。 不保留命名空间前缀。 可以对 XML 字段中的 XML 内容建立索引。 可以对 XML 字段中的 XML 内容建立约束,比如 age 节点必须大于等于 。 可以通过创建架构来对 XML 进行类型化,比如让 xml 内容的 <user> 节点下面必须有 <fullname> 节点。

四、查询操作

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

在T-Sql中,提供了两个对XML类型数据进行查询的函数,分别是query(xquery)和value(xquery, dataType),其中,query(xquery)得到的是带有标签的数据,而value(xquery, dataType)得到的则是标签的内容。接下类我们分别使用这两个函数来进行查询。

1、使用query(xquery) 查询

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

运行结果如图:

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

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

运行结果如图:

3、查询属性值

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

运行结果如图:

4、使用xpath进行查询

xpath是.net平台下支持的,统一的Xml查询语句。使用XPath可以方便的得到想要的节点,而不用使用where语句。例如,

--得到id为的book节点

上面的语句可以独立运行,它得到的是id为的节点。运行结果如下

五、修改操作

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

1、修改节点值

SQL2008 详解直接将XML存入到SQL中(sql server 2008怎么使用sql语句)

我们希望将id为的书的价钱(price)修改为, 我们就可以使用modify方法。代码如下:

--得到id为的book节点

注意:modify方法必须出现在set的后面。运行结果如图:

2、删除节点

接下来我们来删除id为的节点,代码如下:

--删除节点id为的book节点

select @xmlDoc

运行结果如图:

3、添加节点

很多时候,我们还需要向xml里面添加节点,这个时候我们一样需要使用modify方法。下面我们就向id为的book节点中添加一个ISBN节点,代码如下:

--添加节点

运行结果如图:

4、添加和删除属性

当你学会对节点的操作以后,你会发现,很多时候,我们需要对节点进行操作。这个时候我们依然使用modify方法,例如,向id为的book节点中添加一个date属性,用来存储出版时间。代码如下:

--添加属性

运行结果如图:

如果你想同时向一个节点添加多个属性,你可以使用一个属性的集合来实现,属性的集合可以写成:(attribute date{"--"}, attribute year{""}),你还可以添加更多。这里就不再举例了。

5、删除属性

删除一个属性,例如删除id为 的book节点的id属性,我们可以使用如下代码:

--删除属性

运行结果如图:

6、修改属性

修改属性值也是很常用的,例如把id为的book节点的id属性修改为,我们可以使用如下代码:

--修改属性

运行结果如图:

经过上面的学习,相信你已经可以很好的在SQL中使用Xml类型了,下面是我们没有提到的:exist()方法,用来判断指定的节点是否存在,返回值为true或false; nodes()方法,用来把一组由一个查询返回的节点转换成一个类似于结果集的表中的一组记录行。 你可以去MSDN查阅

CentOS 7.3上SQL Server vNext CTP 1.2安装教程 SQLServervNextCTP1.2安装教程:此安装过程参考微软官方的安装文档:

SQLite Delete详解及实例代码 SQLiteDelete详解SQLite的DELETE查询用于删除表中已有的记录。可以使用带有WHERE子句的DELETE查询来删除选定行,否则所有的记录都会被删除。语法带有WHERE子

SQL Server 多表连接查询功能实例代码 废话不多说了,直接给大家贴代码了,具体代码如下所示:--交叉连接产生笛卡尔值(X*Y)SELECT*FROMStudentcrossJoindbo.ClassInfo--另外一种写法SELECT*FROMStudent,ClassI

标签: sql server 2008怎么使用sql语句

本文链接地址:https://www.jiuchutong.com/biancheng/320256.html 转载请保留说明!

上一篇:SQL Server存储过程同时返回分页结果集和总数(sql server存储过程写法)

下一篇:CentOS 7.3上SQL Server vNext CTP 1.2安装教程

  • 详解SQL Server的聚焦过滤索引(sql server基本知识)

    SQL Server对创建索引大小有限制,最大是字节,上述直接写的VARCHAR(MAX),所以会出错,切记,切记。

    此时我们在主键上创建非聚集索引,我们在主键RowID上创建一个过滤索引且SomeValue = 'JeffckyWang" class="img-responsive" alt="详解SQL Server的聚焦过滤索引(sql server基本知识)">

    详解SQL Server的聚焦过滤索引(sql server基本知识)

  • MySQL实现创建存储过程并循环添加记录的方法(mysql怎么创建储存过程)

    MySQL实现创建存储过程并循环添加记录的方法(mysql怎么创建储存过程)

  • windowsXP系统中怎么把虚拟内存调大具体操作步骤(电脑系统xp怎么样)

    windowsXP系统中怎么把虚拟内存调大具体操作步骤(电脑系统xp怎么样)

  • 浅谈python中scipy.misc.logsumexp函数的运用场景(python中scipy.stats)

    浅谈python中scipy.misc.logsumexp函数的运用场景(python中scipy.stats)

  • 个体户定额超了怎么收费
  • 息税前利润含义
  • 财务管理考试时间多长
  • 新企业会计准则2021
  • 个体工商户单位性质怎么填
  • 缴纳增值税会计账务处理
  • 单位买了一批空调怎么办
  • 加计抵减税额账务处理
  • 企业违约金收入会计分录
  • 增值税计算为什么是销项减进项
  • 代订机票被骗可以追回吗
  • 未达起征点是什么
  • 度假村功能
  • 房地产开发企业销售自行开发的房地产项目
  • 促销费可以开专票吗
  • 应付职工薪酬如何具体到个人
  • 企业现金管理办法
  • 票据和结算凭证上的签章
  • 异地上班员工报销路费
  • 应计未计成本税前扣除年限
  • 冲销无形资产如何会计分录?
  • 出口当月开票当月申报吗
  • 贸易公司给客户开发票
  • 金税三期里有员工无工资如何申报?
  • 工业企业水电费如何分摊
  • 建筑行业小规模企业所得税税率
  • 夫妻双方交契税可以一人到嘛
  • 权益性投资损失包括哪些
  • 先缴纳社保还是先扣税
  • 运费允许抵扣的税额分录
  • 资本公积可以退还给投资者吗
  • 年报弥补以前年度亏损了还需要填107040表吗
  • 用友t3怎么增加现金流量项目
  • 出售废品收入
  • 在windows 10中
  • 挂错科目怎么调整
  • 劳务分包费用组成比例
  • 红字专用发票是红色的吗
  • 在路由器设置中怎么设置
  • 系统更新到win11后还可以调回win10吗
  • PHP:mb_convert_kana()的用法_mbstring函数
  • 公司交会费有什么用
  • 分包方可以简易计税吗
  • 为高新技术企业授牌
  • 农村土地承包经营权证丢失怎么补办
  • uniapp微信小程序上传文件
  • 产成品和库存商品两个一级科目怎么填
  • c语言中数组越界
  • 实收资本的会计处理
  • 想要上海名媛群群号
  • 公司员工私车公用协议
  • 购汽车能抵扣进项吗
  • 企业向个人租房发票怎么开
  • 申请制作广告牌的申请
  • 信用减值损失和公允价值变动的区别
  • 材料成本差异会计处理
  • 业务招待费专用会计科目
  • 固定资产清理属于什么科目借方增加还是减少
  • 超期未备案可以投诉么
  • 公司筹建期间预算怎么写
  • 私营公司应付利息怎么算
  • centos6.5中文
  • 电脑太慢了怎么解决
  • linux nc命令详解
  • linux中wc命令的用法
  • font system
  • win7系统无法开机解决方法
  • vb win7
  • windows7的安装步骤
  • win7的命令对话框在哪里
  • Unity3D游戏开发毕业论文
  • node.js gui
  • node.js web
  • javascript要怎么学
  • javascript数据类型有哪些
  • macos如何使用
  • 深入理解新发展理念,推进供给侧结构性改革心得体会
  • 如何用jquery
  • 企业个税网上申报时间
  • 盼之代售怎么下载
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设