mongodb实现数组对象求和方法实例


当前第2页 返回上一页

让我们继续计算,此时只需要使用group与​sum对data里的user字段求和即可,mongodb语句如下:

db.getCollection('user').aggregate([
 {
 $project: { _id: 1, data: 1, date: 1}
 },
 { 
 $match: {"date": "2019-01-18 09"}
 }, 
 {
 $unwind: "$data"
 },
 {
 $match: {
 "data.app_platform": { $in: ["ios"]}
 }
 },
 {
 $group: { _id: null, "user": {$sum: "$data.user"}}
 }
])

结果如下:

/* 1 */
{
    "_id" : null,
    "user" : 7500
}

计算得出的user即我们所需要的数据。

其实所有的难点如下:

  • 计算数组对象数据时将其转变为多条简单的数据格式,$unwind指令将问题轻松得降低了难度
  • mongodb的执行顺序,$project,$match都是顺序执行并作用于之前的操作结果

理解了这两点,相信再难的mongodb语句你也能实现。

happy coding!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。


标签:MongoDB

返回前面的内容

相关阅读 >>

centos7安装mongo数据库的方法(mongo4.2.8)

mongodb修改、删除文档的域属性实例

详解mongodb中的日志模块

mongodb索引使用详解

mongodb 用户管理

对标mongodb存储类json数据文档统计分析详解

mongodb数据库简介与安装方法

mongodb 实现远程连接

详解mongodb范围片键和哈希片键

python3操作mongodb增册改查等方法详解

更多相关阅读请进入《mongodb》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...