10搜索语言--搜索和过滤

查询子句的行为取决于他是在查询上下文中使用,还是在筛选器中使用:
查询上下文:这个查询子句除了决定是否匹配这个文档外,还要知道这个文档和这个查询的匹配程度。所以他会计算一个匹配分数,而分数也取决于其他文档。
过滤上下文:在过滤器上下文中,更多的是回答这个文档是否符合这个请求。结果只有两个是或者不是。所以也就不会涉及到分数计算。更多的,过滤器会涉及到结构化的数据。如:时间是否在2015和2016之间。
为了性能考虑,es会对经常使用的过滤器进行缓存操作。
如下会搜索标题中包含search,正文包括elasticsearch。且状态精确的是published,而且发布时间是2015.1.1之后的数据。
GET /_search
{
"query": {
"bool": {
"must": [
{ "match": { "title": "Search" }},
{ "match": { "content": "Elasticsearch" }}
],
"filter": [
{ "term": { "status": "published" }},
{ "range": { "publish_date": { "gte": "2015-01-01" }}}
]
}
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值