微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sqlserver xml查询

declare @UsersList Xml
set @UsersList='<department></department><Users>
<ID val="cc">PC00000000002615</ID>
<ID val="bb">PC00000000009999</ID>
</Users>' 
Select ID.value('.','nvarchar(40)') AS USERSID,ID.value('./@val','nvarchar(40)')
From @UsersList.nodes('/Users/ID') AS USERSID(ID)

Select COUNT(ID.value('@val','nvarchar(40)'))
From @UsersList.nodes('/Users/ID') AS USERSID(ID)

Select COUNT(1)
From @UsersList.nodes('/UseRSS/IDs') AS USERSID(ID)



Select @UsersList.query('/Users/ID') --查询XML中Users节点下所有子节点是ID的串
Select @UsersList.query('/Users/ID').value('.','NVarchar(40)') --查询XML中Users节点下所有子节点是ID的值
Select @UsersList.query('/Users/ID[@val="cc"]') --查询XML中Users节点下所有子节点是ID,并且val属性是cc的节点
Select @UsersList.query('/Users/ID[@val="cc"]').value('.','NVarchar(40)') --查询XML中Users节点下所有子节点是ID,并且val属性是cc的节点的值
Select @UsersList.query('/Users/ID/text()[0]') --取Users节点下子节点是ID的值,顺序从1开始,不存在将以空串显示
Select @UsersList.query('(/Users/ID/text())[1]')
Select @UsersList.query('(/Users/ID/text())[2]')
Select @UsersList.query('(/Users/ID/text())[3]') 

Select ID.value('.','nvarchar(40)') AS USERSID    --ID值相同 *将XML串转换成表形式显示*
From @UsersList.nodes('/Users/ID') AS USERSID(ID)

Select ID.value('.','nvarchar(40)') AS USERSID    --ID值相同只取属性是cc的记录行 *将XML串转换成表形式显示*
From @UsersList.nodes('/Users/ID[@val="cc"]') AS USERSID(ID)

Select ID2.value('.','nvarchar(40)') AS USERSID    --ID2相同
From @UsersList.nodes('/Users/ID2') AS USERSID(ID2)

Select ID2.value('.','nvarchar(40)') AS USERSID 
From @UsersList.nodes('/Users/ID') AS USERSID(ID2)


版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐