加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQLServer XML数据的五种基本操作

发布时间:2020-12-12 09:36:08 所属栏目:MsSql教程 来源:网络整理
导读:1.xml.exist 输入为XQuery表达式,返回0,1或是Null。0表示不存在,1表示存在,Null表示输入为空 2.xml.value 输入为XQuery表达式,返回一个SQL Server标量值 3.xml.query 输入为XQuery表达式,返回一个SQL Server XML类型流 4.xml.nodes 输入为XQuery表达式

1.xml.exist
输入为XQuery表达式,返回0,1或是Null。0表示不存在,1表示存在,Null表示输入为空
2.xml.value
输入为XQuery表达式,返回一个SQL Server标量值
3.xml.query
输入为XQuery表达式,返回一个SQL Server XML类型流
4.xml.nodes
输入为XQuery表达式,返回一个XML格式文档的一列行集
5.xml.modify
使用XQuery表达式对XML的节点进行insert,update 和 delete 操作。
下面通过例子对上面的五种操作进行说明:
declare @XMLVar xml = '

<book category="ITPro">
Windows Step By Step
Bill Zack
49.99

<book category="Developer">
Developing ADO .NET
Andrew Brust
39.93

<book category="ITPro">
Windows Cluster Server
Stephen Forte
59.99

'
1. xml.exist
select @XMLVar.exist('/catalog/book')-----返回1
select @XMLVar.exist('/catalog/book/@category')-----返回1
select @XMLVar.exist('/catalog/book1')-----返回0
set @XMLVar = null
select @XMLVar.exist('/catalog/book')-----返回null
2.xml.value
select @XMLVar.value('/catalog[1]/book[1]','varchar(MAX)')
select @XMLVar.value('/catalog[1]/book[2]/@category','varchar(MAX)')
select @XMLVar.value('/catalog[2]/book[1]','varchar(MAX)')
结果集为:
Windows Step By StepBill Zack49.99 Developer NULL
3.xml.query
select @XMLVar.query('/catalog[1]/book')
select @XMLVar.query('/catalog[1]/book[1]')
select @XMLVar.query('/catalog[1]/book[2]/author')
结果集分别为:
<book category="ITPro">
Windows Step By Step
Bill Zack
49.99

<book category="Developer">
Developing ADO .NET
Andrew Brust
39.93

<book category="ITPro">
Windows Cluster Server
Stephen Forte
59.99

<book category="ITPro">
Windows Step By Step
Bill Zack
49.99

Andrew Brust
4.xml.nodes
select T.c.query('.') as result from @XMLVar.nodes('/catalog/book') as T(c)
select T.c.query('title') as result from @XMLVar.nodes('/catalog/book') as T(c)
结果集分别为:
<book category="ITPro">Windows Step By StepBill …………
<book category="Developer">Developing ADO .NETAndrew …………
<book category="ITPro">Windows Cluster ServerStephen …………
Windows Step By Step
Developing ADO .NET
Windows Cluster Server
5.xml.modify
关于modify内容,请参见下一篇文章。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读