ElasticSearch - How can i apply a filter over the results of the query to limit the document that have a certain value

荒凉一梦 提交于 2021-01-01 17:46:31

问题


I have a question regarding elastic search but I am not sure where to start searching or which precise operation I should search for using google.

Let say I have a document with data and one of its fields is "the_best" (which is a boolean). The thing is (currently), over 48 results (given by a working query), I have like 15 documents returned with the_best field set to true.

Now, I would like to limit this by only 2 maximum documents set to true over the results. So now, it (elasticsearch) should now return 35 results (if we stik at the story above):

  • Base (out of 48results): [15 the_best=true, 33 the_best=false]
  • Expected (with max 2 the_best=true): I should get 35 results [2 the_best=true, 33 the_best=false])

Any idea? :)


回答1:


One way to do is using m_search

using m_Search you can combine multiple queries

GET <index>/_msearch
{}
{"query":{"term":{"the_best":true}},"from":0,"size":2}
{}
{"query":{"term":{"the_best":false}},"from":0,"size":15}

If you want to do it in single search aggregation can be used(will be less performant)

I have used filter aggregation and top_hits aggregation

{
  "size": 0, 
  "aggs": {
    "true": {
      "filter": {
        "term": {
          "the_best": true
        }
      },
      "aggs": {
        "docs": {
          "top_hits": {
            "size": 2
          }
        }
      }
    },
    "false": {
      "filter": {
        "term": {
          "the_best": false
        }
      },
      "aggs": {
        "docs": {
          "top_hits": {
            "size": 10
          }
        }
      }
    }
  }
}



来源:https://stackoverflow.com/questions/65425695/elasticsearch-how-can-i-apply-a-filter-over-the-results-of-the-query-to-limit

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!