• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    mongodb实现数组对象求和方法实例

    前言

    mongodb在计算集合数组值时候,我们通常会想到使用$group与$sum,但是如果是数组里面多个json对象,并且还需要根据条件过滤多个对象的内容该如何处理?

    现在让我们来实现它,假设mongodb中有个user集合,其数据内容如下:

    /* 1 */
    {
     "_id" : ObjectId("5c414a6a0847e00385143003"),
     "date" : "2019-01-18 09",
     "data" : [ 
     {
      "app_platform" : "ios",
      "user" : 3028
     }, 
     {
      "app_platform" : "android",
      "user" : 4472
     }, 
     ]
    }
    ...

    现在我们需要计算date日期为"2019-01-18 09"并且app_platform的类型为"ios"的user总数

    如果可以,请先思考下mongodb语句如何实现。

    实现过程中有个执行非常重要,即$unwind,官方解释:

    Deconstructs an array field from the input documents to output a document for each element. Each output document is the input document with the value of the array field replaced by the element.

    从输入文档中解构一个数组字段,为每个元素输出一个文档。每个输出文档都是输入文档,数组字段的值由元素替换。

    于是我们便想到将data数组对象分条拆开,化繁为简,mongodb语句如下:

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

    得到结果如下:

    /* 1 */
    {
        "_id" : ObjectId("5c414a6a0847e00385143003"),
        "date" : "2019-01-18 09",
        "data" : {
            "app_platform" : "ios",
            "user" : 3028
        }
    }
    /* 2 */
    {
        "_id" : ObjectId("5c414a6a0847e00385143003"),
        "date" : "2019-01-18 09",
        "data" : {
            "app_platform" : "android",
            "user" : 4472
        }
    }

    可以看到数据由数组变成了多条文档数据,于是问题转变为计算结果的user总数,是不是觉得问题变简单了,而且我们也可以继续使用$match来过滤app_platform数据,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"]}
     },
     }
    ])

    执行结果如下:

    /* 1 */
    {
        "_id" : ObjectId("5c414a6a0847e00385143003"),
        "date" : "2019-01-18 09",
        "data" : {
            "app_platform" : "ios",
            "user" : 3028
        }
    }

    可以看到数据已经被过滤了,如果自信观察两个$match的作用可以发现,mongodb是按顺序执行的,即$match作用于其前面的操作结果集合

    让我们继续计算,此时只需要使用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即我们所需要的数据。

    其实所有的难点如下:

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

    happy coding!

    总结

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

    您可能感兴趣的文章:
    • Python实现读取SQLServer数据并插入到MongoDB数据库的方法示例
    • Python实现批量读取图片并存入mongodb数据库的方法示例
    • mongoDB 实现主从读写分离实现的实例代码
    • python读取json文件并将数据插入到mongodb的方法
    • 了不起的node.js读书笔记之mongodb数据库交互
    • mongodb的写操作
    • mongodb与sql关系型数据比较
    • mongodb使用c#驱动数据插入demo
    • c#操作mongodb插入数据效率
    • Mongodb读数据操作
    上一篇:MongoDB中唯一索引(Unique)的那些事
    下一篇:c#操作mongodb插入数据效率
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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