主页 > 知识库 > sqlserver2005 xml字段的读写操作

sqlserver2005 xml字段的读写操作

热门标签:北京智能外呼系统供应商家 孝感销售电销机器人厂家 江西稳定外呼系统供应商 中国地图标注省份用什么符号 奥维地图标注字体大小修改 无锡梁溪公司怎样申请400电话 电话机器人录音师薪资 智能电销机器人教育 高德地图标注电话怎么没了
1.创建xml字段
在表xmlTest内创建一个字段,命名_x,设置数据类型为xml。
2.写入xml
insert into xmlTest (_x) values('
root>
item attr1="a1" attr2="a2">item11/item>
item attr1="a1" attr2="a2">item12/item>
/root>
')
go
如此再插入一条记录:
insert into xmlTest (_x) values('
root>
item attr1="b1" attr2="b2">item21/item>
item attr1="b1" attr2="b2">item22/item>
/root>
')
3.查询数据
3.1 查询字段所有数据
select _x from xmlText
结果如图:

3.2 查询root下面的第一个item节点
select _x.query('root/item[1]')
from xmlTest
结果:

3.3 查询root下面的第一个item节点的值
select _x.value('(root/item)[1]','varchar(50)')
from xmlTest
结果:

3.3 查询root下面的第二个item节点的attr2属性值
select _x.value('(root/item/@attr2)[2]','varchar(50)')
from xmlTest
结果:

3.4 查询表中每条记录的xml字段的item节点值,全部列出来
SELECT t2.c1.value('.','varchar(20)') as items
from xmlTest
cross apply _x.nodes('root/item') as t2(c1)
结果:

3.5 查询表中id=1记录的xml的所有item字段的attr2属性值
SELECT t2.c1.value('@attr2','varchar(20)') as attr2
from xmlTest
cross apply _x.nodes('root/item') as t2(c1)
where id='1'

结果:

3.6 查询id为1的所有节点中attr1属性为a1的第一个匹配节点的attr2属性值

select _x.value('(root/item[@attr1="a1"]/@attr2)[1]','varchar(50)')
from xmlTest where id='1'

结果:

3.7 多表查询

例如:存在另外1个table:t2,其字段xmlid关联表xmlTest,而attr1关联xmlTest的_x字段中的attr1属性值。

查询表xmlTest中id=‘1'记录中_x字段内item节点中attr1为表t2中attr1字段值时,item节点中attr2的属性值

select xmlTest._x.value('(root/item[@attr1=sql:column("t2.attr1")]/@attr2)[1]','varchar(50)') as attr2,t2.attr1
from xmlTest join t2 on t2.xmlid=xmlTest.id
where xmlTest.id='1'

4.修改数据
4.1 修改表中id=1记录的第一个item节点值
UPDATE xmlTest
set _x.modify('replace value of (root/item/text())[1] with "xxxxx"')
where id='1'

select _x.query('root/item[1]') as item1
from xmlTest
结果:

4.2 修改表中id=2记录的第二个item节点的attr2属性值
UPDATE xmlTest
set _x.modify('replace value of (root/item/@attr2)[2] with "2222b"')
where id='2'

select _x.query('root/item[2]') as item1
from xmlTest
结果:

您可能感兴趣的文章:
  • SQLServer XML数据的五种基本操作
  • C#怎样才能将XML文件导入SQL Server
  • SQLServer XML查询快速入门(18句话)
  • SqlServer参数化查询之where in和like实现之xml和DataTable传参介绍
  • Sqlserver 2005使用XML一次更新多条记录的方法
  • 在SQL Server中将数据导出为XML和Json的方法
  • SQLServer XML查询18句话入门教程
  • SQL Server解析XML数据的方法详解

标签:通化 海北 荆州 临沧 阜阳 泰州 那曲 齐齐哈尔

巨人网络通讯声明:本文标题《sqlserver2005 xml字段的读写操作》,本文关键词  sqlserver2005,xml,字段,的,读写,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《sqlserver2005 xml字段的读写操作》相关的同类信息!
  • 本页收集关于sqlserver2005 xml字段的读写操作的相关信息资讯供网民参考!
  • 推荐文章