ElasticSearch-使用FilterBuilders
我是ElasticSearch和Couchbase的新手。我正在构建一个示例Java应用程序,以了解有关ElasticSearch和Couchbase的更多信息。
阅读ElasticSearch Java
API时,在不需要按分数排序和进行缓存的情况下,可以更好地使用过滤器。我仍然没有弄清楚如何使用FilterBuilders并有以下问题:
- 可以
FilterBuilders
单独使用进行搜索吗? - 还是必须始终将它们与一起使用
Query
?(如果为true,请问有人可以列举一个例子吗?) - 查看文档,如果我想基于字段值执行搜索并想使用FilterBuilders,该如何实现?(使用
AndFilterBuilder
或TermFilterBuilder
或InFilterBuilder
?我不清楚它们之间的区别。)
对于第三个问题,我实际上通过使用查询和过滤器的搜索对它进行了测试,如下所示。尝试使用进行搜索时,结果为空(无行)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);
}
-- *
如答案中所建议,更改为小写的“ tx”是可行的。这个问题解决了。我仍然有以下问题:
- 在什么情况下,查询会使用过滤器?这将达到什么目的?
- 之间的区别
InFilter
,TermFilter
和MatchAllFilter
。任何插图都将有所帮助。
回答:
正确,您应该使用过滤器来排除执行查询时甚至不考虑的文档。筛选器速度更快,因为它们不涉及任何评分,并且也可以缓存。
也就是说,很明显,您必须对search
api使用过滤器,该api会执行查询并接受可选过滤器。如果只有过滤器,则可以将match_all查询与过滤器一起使用。过滤器可以是简单过滤器,也可以是复合过滤器,以便将多个过滤器组合在一起。
关于Java API,使用的名称是可用过滤器的名称,没有太大区别。例如,看看这个搜索示例。在您的代码中,我看不到您setFilter
在SearchRequestBuilder
对象上的位置。您似乎也不需要和过滤器,因为您使用的是单个过滤器。此外,可能是您正在使用默认映射建立索引,因此术语“
TX”是小写的。因此,当您使用术语过滤器进行搜索时,找不到任何匹配项。尝试搜索小写的“ tx”。
如果要在索引时保持“
TX”术语不变,则可以更改映射,也可以将字段设置为not_analyzed
仅作为单个标记。否则,您可以更改过滤器,您可能希望查看已分析的查询,以便以与索引内容相同的方式来分析您的查询。
请查看查询DSL文档,以获取有关查询和过滤器的更多信息:
MatchAllFilter
:匹配您所有的文档,我不会说那么有用TermFilter
:过滤具有包含术语(未分析)的字段的文档AndFilter
:用于放入的复合过滤器和两个或多个过滤器
不知道您的意思是InFilterBuilder
,找不到任何使用此名称的过滤器。
该查询通常包含用户在文本搜索框中键入的内容。过滤器是优化搜索的更多方式,例如单击构面条目。因此,您仍然需要查询加上一个或多个过滤器。
以上是 ElasticSearch-使用FilterBuilders 的全部内容, 来源链接: utcz.com/qa/425895.html