ElasticSearch – 使用FilterBuilders

我是ElasticSearch和Couchbase的新手。 我正在构建一个示例Java应用程序,以了解有关ElasticSearch和Couchbase的更多信息。

阅读ElasticSearch Java API ,在不需要排序分数和缓存的情况下,可以更好地使用filter。 我仍然没有想出如何使用FilterBuilders并有以下问题:

  • 可以单独使用FilterBuilders进行搜索吗?
  • 或者它们是否总是必须与Query一起使用? (如果是真的,有人可以列举一个例子吗?)
  • 浏览文档,如果我想根据字段值执行搜索并想要使用FilterBuilders,我该如何实现? (使用AndFilterBuilderTermFilterBuilderInFilterBuilder ?我不清楚它们之间的区别。)

对于第3个问题,我实际上使用查询和使用filter进行了测试,如下所示。 当我尝试使用FilterBuilders搜索时,我得到了空结果(没有行)。 我不确定我做错了什么。

任何例子都会有所帮助。 我经历过艰难的时间浏览文档,我发现稀疏甚至搜索导致各种不可靠的用户论坛。

 private void processQuery() { SearchRequestBuilder srb = getSearchRequestBuilder(BUCKET); QueryBuilder qb = QueryBuilders.fieldQuery("doc.address.state", "TX"); srb.setQuery(qb); SearchResponse resp = srb.execute().actionGet(); System.out.println("response :" + resp); } private void searchWithFilters(){ SearchRequestBuilder srb = getSearchRequestBuilder(BUCKET); srb.setFilter(FilterBuilders.termFilter("doc.address.state", "tx")); //AndFilterBuilder andFb = FilterBuilders.andFilter(); //andFb.add(FilterBuilders.termFilter("doc.address.state", "TX")); //srb.setFilter(andFb); SearchResponse resp = srb.execute().actionGet(); System.out.println("response :" + resp); } 

-UPDATE–

如答案所示,更改为小写“tx”有效。 随着这个问题的解决。 我还有以下问题:

  • 在什么情况下,filter与查询一起使用? 这有什么用途?
  • InFilterTermFilterMatchAllFilter之间的InFilter 。 任何插图都会有帮助。

是的,您应该使用filter来排除在执行查询时甚至不考虑文档。 filter更快,因为它们不涉及任何评分,也可以缓存。

也就是说,很明显你必须使用带有搜索api的filter,它会执行查询并接受可选的filter。 如果您只有filter,则可以将match_all查询与filter一起使用。 filter可以是简单的filter,也可以是复合filter,以便将多个filter组合在一起。

关于Java API ,使用的名称是可用filter的名称,没有太大区别。 例如 ,看看这个搜索示例 。 在您的代码中,我没有看到您在SearchRequestBuilder对象上执行setFilter 。 您似乎不需要和filter,因为您使用的是单个filter。 此外,可能是您使用默认映射进行索引,因此术语“TX”是小写的。 这就是为什么当您使用术语filter进行搜索时,您找不到任何匹配项。 尝试搜索“tx”小写。

如果要在索引时保留“TX”术语,可以更改映射,如果字段应该只是单个标记,则可能将字段设置为not_analyzed 。 否则,您可以更改filter,您可能希望查看已分析的查询,以便以与索引内容相同的方式分析您的查询。

有关查询和filter的更多信息,请查看查询DSL文档 :

  • MatchAllFilter :匹配你的所有文件,而不是我说的那么有用
  • TermFilter :筛选包含术语(未分析)的字段的文档
  • AndFilter :用于放入复合filter和两个或多个filter

不知道你的意思是InFilterBuilder ,找不到任何带有这个名字的filter。

查询通常包含用户通过文本搜索框键入的内容。 filter是优化搜索的更多方法,例如单击构面条目。 这就是为什么你仍然会有查询加一个或多个filter。

附加@javanna所说的:

可以通过以下几种方式定义filter,从而产生很多混淆:

你可能会问有什么不同。 事实上,你可以在两个方面构建完全相同的逻辑。

不同之处在于查询对结果集以及您定义的任何方面进行操作。 然而,filter(当定义为独立时)仅对结果集进行操作,而不是对您可能定义的任何方面进行操作(在此处解释: http : //www.elasticsearch.org/guide/reference/api/search/filter/ )

要添加到其他答案,InFilter仅用于FilterBuilders。 定义是,InFilter:基于与其中任何一个匹配的几个术语的字段的filter。

查询Java API使用FilterBuilders,它是可以从Java代码动态创建查询的filter构建器的工厂。 我们使用表单执行此操作,并根据用户选择使用复选框,选项和下拉列表构建查询。

以下是FilterBuilders的一些示例代码,该链接中有一个使用InFilter的代码段,如下所示:

 FilterBuilder filterBuilder; User user = (User) auth.getPrincipal(); if (user.getGroups() != null && !user.getGroups().isEmpty()) { filterBuilder = FilterBuilders.boolFilter() .should(FilterBuilders.nestedFilter("userRoles", FilterBuilders.termFilter("userRoles.key", auth.getName()))) .should(FilterBuilders.nestedFilter("groupRoles", FilterBuilders.inFilter("groupRoles.key", user.getGroups().toArray()))); } else { filterBuilder = FilterBuilders.nestedFilter("userRoles", FilterBuilders.termFilter("userRoles.key", auth.getName())); } ... 
Interesting Posts