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" }}} 
      ]
    }
  }
}

猜你喜欢

转载自fenshen6046.iteye.com/blog/2369694
今日推荐