首页 > 解决方案 > 是否可以在 mongo db 中聚合 $$ROOT?

问题描述

我有以下 Mongo Collection。

[
  {
    "query": "a",
    "page": "p1",
    "clicks": 10,
    "date": "x"
  },
  {
    "query": "b",
    "page": "p1",
    "clicks": 5,
    "date": "x"
  },
  {
    "query": "a",
    "page": "p1",
    "clicks": 5,
    "date": "y"
  },
  {
    "query": "c",
    "page": "p2",
    "clicks": 2,
    "date": "y"
  },
  
]

输出应该是这样的:

 [
      {
        "page" : "p1",
        "most_clicks_query" : "a",
        "sum_of_clicks_for_query" : 15

      },
{
        "page" : "p2",
        "most_clicks_query" : "c",
        "sum_of_clicks_for_query" : 2

      },
  
      
    ]

获得此输出的逻辑

我需要每个页面点击次数最多的查询名称(对于该查询)

我问的是

标签: mongodbaggregation-framework

解决方案


这是您正在寻找的聚合:

db.collection.aggregate([
  {
    "$group": {
      "_id": {
        "page": "$page",
        "query": "$query"
      },
      "sum_of_clicks_for_query": {
        "$sum": "$clicks"
      }
    }
  },
  {
    "$project": {
      "_id": false,
      "page": "$_id.page",
      "most_clicks_query": "$_id.query",
      "sum_of_clicks_for_query": true
    }
  },
  {
    $sort: {
      "sum_of_clicks_for_query": -1
    }
  },
  {
    $group: {
      _id: "$page",
      group: {
        $first: "$$ROOT"
      }
    }
  },
  {
    $replaceRoot: {
      newRoot: "$group"
    }
  }
])

游乐场:https ://mongoplayground.net/p/Uzk3CuSwVRM


推荐阅读