| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 | [[query-dsl-filtered-query]]=== Filtered Querydeprecated[2.0.0, Use the `bool` query instead with a `must` clause for the query and a `filter` clause for the filter]The `filtered` query is used to combine a query which will be used forscoring with another query which will only be used for filtering the resultset.TIP: Exclude as many document as you can with a filter, then query just thedocuments that remain.[source,js]--------------------------------------------------{  "filtered": {    "query": {      "match": { "tweet": "full text search" }    },    "filter": {      "range": { "created": { "gte": "now - 1d / d" }}    }  }}--------------------------------------------------The `filtered` query can be used wherever a `query` is expected, for instance,to use the above example in search request:[source,js]--------------------------------------------------curl -XGET localhost:9200/_search -d '{  "query": {    "filtered": { <1>      "query": {        "match": { "tweet": "full text search" }      },      "filter": {        "range": { "created": { "gte": "now - 1d / d" }}      }    }  }}'--------------------------------------------------<1> The `filtered` query is passed as the value of the `query`    parameter in the search request.==== Filtering without a queryIf a `query` is not specified, it defaults to the<<query-dsl-match-all-query,`match_all` query>>.  This means that the`filtered` query can be used to wrap just a filter, so that it can be usedwherever a query is expected.[source,js]--------------------------------------------------curl -XGET localhost:9200/_search -d '{  "query": {    "filtered": { <1>      "filter": {        "range": { "created": { "gte": "now - 1d / d" }}      }    }  }}'--------------------------------------------------<1> No `query` has been specified, so this request applies just the filter,   returning all documents created since yesterday.===== Multiple filtersMultiple filters can be applied by wrapping them in a<<query-dsl-bool-query,`bool` query>>, for example:[source,js]--------------------------------------------------{  "filtered": {    "query": { "match": { "tweet": "full text search" }},    "filter": {      "bool": {        "must": { "range": { "created": { "gte": "now - 1d / d" }}},        "should": [          { "term": { "featured": true }},          { "term": { "starred":  true }}        ],        "must_not": { "term": { "deleted": false }}      }    }  }}--------------------------------------------------===== Filter strategyYou can control how the filter and query are executed with the `strategy`parameter:[source,js]--------------------------------------------------{    "filtered" : {        "query" :   { ... },        "filter" :  { ... },        "strategy": "leap_frog"    }}--------------------------------------------------IMPORTANT: This is an _expert-level_ setting.  Most users can simply ignore it.The `strategy` parameter accepts the following options:[horizontal]`leap_frog_query_first`::        Look for the first document matching the query, and then alternatively        advance the query and the filter to find common matches.`leap_frog_filter_first`::    Look for the first document matching the filter, and then alternatively    advance the query and the filter to find common matches.`leap_frog`::    Same as `leap_frog_query_first`.`query_first`::    If the filter supports random access, then search for documents using the    query, and then consult the filter to check whether there is a match.    Otherwise fall back to `leap_frog_query_first`.`random_access_${threshold}`::    If the filter supports random access and if the number of documents in the    index divided by the cardinality of the filter is greater than ${threshold},    then apply the filter first.    Otherwise fall back to `leap_frog_query_first`. `${threshold}` must be    greater than or equal to `1`.`random_access_always`::    Apply the filter first if it supports random access. Otherwise fall back    to `leap_frog_query_first`.The default strategy is to use `query_first` on filters that are notadvanceable such as geo filters and script filters, and `random_access_100` onother filters.
 |