zoukankan      html  css  js  c++  java
  • mongo简单的聚合使用

    mongo 聚合索引

    • 根据某字段进行分组统计

      • 数据源结构

        { "_id" : ObjectId("5fc7694da343baa23c0b2d75"), "id" : 0, "age" : 13, "name" : "name869", "created" : ISODate("2020-12-02T10:15:41.615Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d76"), "id" : 1, "age" : 101, "name" : "name471", "created" : ISODate("2020-12-02T10:15:41.616Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d77"), "id" : 2, "age" : 29, "name" : "name115", "created" : ISODate("2020-12-02T10:15:41.616Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d78"), "id" : 3, "age" : 73, "name" : "name382", "created" : ISODate("2020-12-02T10:15:41.616Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d79"), "id" : 4, "age" : 1, "name" : "name258", "created" : ISODate("2020-12-02T10:15:41.617Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d7a"), "id" : 5, "age" : 117, "name" : "name586", "created" : ISODate("2020-12-02T10:15:41.617Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d7b"), "id" : 6, "age" : 29, "name" : "name15", "created" : ISODate("2020-12-02T10:15:41.618Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d7c"), "id" : 7, "age" : 55, "name" : "name774", "created" : ISODate("2020-12-02T10:15:41.618Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d7d"), "id" : 8, "age" : 14, "name" : "name138", "created" : ISODate("2020-12-02T10:15:41.619Z") }
        { "_id" : ObjectId("5fc7694da343baa23c0b2d7e"), "id" : 9, "age" : 63, "name" : "name920", "created" : ISODate("2020-12-02T10:15:41.619Z") }
        
      • 假设根据 name 进行聚合统计

        1. 查询映射到指定的字段 使用关键字 $project

          {"$project":{"name":1}}
          
        2. name字段进行分组,并计算总出现的次数 count

          {"$group":{"_id":"$name","count":{"$sum":1}}}
          
        3. 对已经计算好的次数进行排序 使用关键字 $sort

          {"$sort":{"count":-1}} # -1 代表降序  1 代表升序
          
        4. 取出前10条记录

          {"$limit":10}
          
        5. 将以上的步骤都需要放在聚合查询的函数里 关键字 aggregate

          db.blog.aggregate(
              {"$project":{"name":1}},
              {"$group":{"_id":"$name","count":{"$sum":1}}},
              {"$sort":{"count":-1}},
              {"$limit":10}
          )
          
  • 相关阅读:
    关于SQL存储过程的问题
    Community Server的体系结构
    cs_Moderate_ApprovePost///cs_Moderate_CheckUser///cs_Moderate_DeletePost
    计划失败
    Menu 菜单栏
    基于混合云存储系统的电影推荐引擎小结
    zookeeper运维管理
    环境变量问题
    关于库
    腾讯猜字游戏
  • 原文地址:https://www.cnblogs.com/wuxiaoshi/p/14075911.html
Copyright © 2011-2022 走看看