您现在的位置是:网站首页> 编程资料编程资料
sqlserver2005 xml字段的读写操作_mssql2005_
2023-05-27
475人已围观
简介 sqlserver2005 xml字段的读写操作_mssql2005_
在表xmlTest内创建一个字段,命名_x,设置数据类型为xml。
2.写入xml
insert into xmlTest (_x) values('
')
go
如此再插入一条记录:
insert into xmlTest (_x) values('
')
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 2005系统配置要求官方说明_mssql2005_
- winXP系统安装SQLServer2005开发版具体过程与注意问题_mssql2005_
- sqlserver2005 安装图解教程以及SQL 2005 SP3补丁安装图文教程_mssql2005_
- 超详细的sql2005图解安装全过程第1/2页_mssql2005_
- sql2005开发版 没有任何功能可以安装_mssql2005_
- 安装SQL2005提示 找不到任何SQL2005组件的问题解决方案_mssql2005_
- SQLServer ntile获取每组前10%的数据_mssql2005_
- SQLServer 设置单词首字母大写_mssql2005_
- SQLServer2005 Output子句获取刚插入的ID值_mssql2005_
- SQLServer2005 批量查询自定义对象脚本_mssql2005_
