你的位置:首页 > 数据库

[数据库]知方可补不足~sqlserver中对xml类型字段的操作


回到目录

在sqlserver中有很多种数据类型,而

表test有字段Menu,它保存的信息可能有两种方式,对标准menu,扩展menu,自定义Menu等,而这些方式所需要的键/值是不同的,有些同学会说使用Json串来存储,这当然是一种很不错的方式,但是数据库并没有这种类型,所以在查询,聚合时非常困难,这些我们想到了

1 XML字段结构如下

<WxPaymentConfig>  <demo>zhang</demo>  <price>1000</price> </WxPaymentConfig>

2 查询数据,通过XML类型作为条件

SELECT *FROM  demoWHERE  Menu.value('(/WxPaymentConfig/demo)[1]', 'nvarchar(50)') = 'zhang'

3 查询数据同时对它进行统计,即执行某些聚合操作

SELECT SUM(Menu.value('(/WxPaymentConfig/price)[1]', 'decimal'))FROM  demoWHERE  Menu.value('(/WxPaymentConfig/demo)[1]', 'nvarchar(50)') = 'zhang'

结果是我们所希望看到的

回到目录