匹配与其他查询的布尔组合匹配的文档的查询。bool查询映射到Lucene BooleanQuery。它是使用一个或多个布尔子句构建的,每个子句都有一个有类型的occurrence。occurrence的类型有:
查询子句语句 | 描述信息 |
---|---|
must | 匹配的文档必须满足的子句,并会用于计算分数 |
filter | 匹配的文档必须满足的子句,但不会向must一样计算分数,分数被忽略,Filter子句在Filter上下文中运行,这意味着计分被忽略,并且子句被考虑用于缓存 |
should | 匹配的文档可能满足的子句,不是一定需要满足 |
must_not | 匹配的文档必须不满足子句,子句在Filter上下文中执行,计分被忽略,并且会使用缓存,由于计分被忽略,因此所有文档的分数返回均为0 |
布尔查询采用的是“更好匹配”的方法,因此,每个匹配的must或should子句的得分将加在一起,以提供每个文档的最终_score。
POST http://localhost:9200/person/_search
{
"query": {
"bool" : {
"must" : {
"term" : { "user.id" : "kimchy" }
},
"filter": {
"term" : { "tags" : "production" }
},
"must_not" : {
"range" : {
"age" : { "gte" : 10, "lte" : 20 }
}
},
"should" : [
{ "term" : { "tags" : "env1" } },
{ "term" : { "tags" : "deployed" } }
],
"minimum_should_match" : 1,
"boost" : 1.0
}
}
}
user.id必须为kimchy,并且tags为env1或者deployed,过滤阶段tags必须为production并且age不能在[10, 20]内
使用minimum_should_match
您可以使用minimum_should_match
参数指定返回的文档必须匹配的should子句的数量或百分比。
如果布尔查询包含至少一个should子句,并且没有must或filter子句,则默认值为1。否则,默认值为0。
bool.filter与计分
在filter子句下的查询元素对计分没有影响——所有分数都是0。分数仅受指定查询的影响。例如,下面有三个查询,都是返回status为active的所有文档。
第一个查询给所有文档赋0分,因为没有指定评分查询:
{
"query": {
"bool": {
"filter": {
"term": {
"status": "active"
}
}
}
}
}
这个bool查询有一个match_all查询,它给所有文档赋1.0分:
{
"query": {
"bool": {
"must": {
"match_all": {}
},
"filter": {
"term": {
"status": "active"
}
}
}
}
}
Constant_score查询的行为方式与上面的第二个示例完全相同。constant_score查询为筛选器匹配的所有文档分配一个1.0的分数:
{
"query": {
"constant_score": {
"filter": {
"term": {
"status": "active"
}
}
}
}
}
命名查询
每个查询在其顶级定义中接受_name。可以使用命名查询来跟踪哪些查询匹配返回的文档。如果使用了命名查询,则响应都包含一个matched_queries属性描述是哪一个子句命中。
{
"query": {
"bool": {
"should": [
{ "match": { "name.first": { "query": "shay", "_name": "first" } } },
{ "match": { "name.last": { "query": "banon", "_name": "last" } } }
],
"filter": {
"terms": {
"name.last": [ "banon", "kimchy" ],
"_name": "test"
}
}
}
}
}