агрегация эластичного поиска при агрегации - PullRequest
0 голосов
/ 24 сентября 2018

У меня есть несколько проиндексированных записей, таких как:

{
 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 в качестве входных данных, и агрегация должна сказать, какие песни были загружены обоими пользователями.Я ожидаю, что результат покажет мне song_id 123, если мой ввод был user_id's 1000 и 1001.

Notice

  • Некоторые песни могут быть загружены пользователем дважды или более.

@ andrei-stefan

1 Ответ

0 голосов
/ 25 сентября 2018
{
  "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"
          }
        }
      }
    }
  }
}
...