首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >关于聚合的elasticsearch聚合

关于聚合的elasticsearch聚合
EN

Stack Overflow用户
提问于 2018-09-24 14:34:10
回答 1查看 45关注 0票数 0

我有一些这样的索引记录:

代码语言:javascript
复制
{
 song_id: 123,
 user_id: 1000,
 date: "2018-06-04T16:01:20"
},{
 song_id: 123,
 user_id: 1000,
 date: "2018-05-03T14:21:17"
},{
 song_id: 123,
 user_id: 1001,
 date: "2018-05-25T22:54:37"
},{
 song_id: 124,
 user_id: 1001,
 date: "2018-04-25T22:54:37"
}

现在,我想使用两个user_id作为输入进行聚合查询,聚合应该说明两个用户下载了哪些歌曲。如果我的输入是user_id的song_id _ 1231001,那么我希望得到的结果显示了123

通知

  • 有些歌曲可能被用户下载了两次或更多。

@andrei-stefan

EN

回答 1

Stack Overflow用户

发布于 2018-09-25 20:50:33

代码语言:javascript
复制
{
  "from": 0,
  "size": 0,
  "query": {
    "bool": {
      "must": [
        {
          "bool": {
            "should": [
              {
                "match": {
                  "user_id": 1000
                }
              },
              {
                "match": {
                  "user_id": 1001
                }
              }
            ]
          }
        }
      ]
    }
  },
  "aggs": {
    "songs": {
      "terms": {
        "size": 1000, 
        "field": "song_id",
        "order": {
          "_count": "desc"
        }
      },
      "aggs": {
        "should_we_consider": {
          "bucket_selector": {
            "buckets_path": {
              "hits": "users._bucket_count"
            },
            "script": "params.hits == 2"
          }
        },
        "users": {
          "terms": {
            "field": "user_id"
          }
        }
      }
    }
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52481676

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档