当前位置:  开发笔记 > 编程语言 > 正文

ElasticSearch - 使用FilterBuilders

如何解决《ElasticSearch-使用FilterBuilders》经验,为你挑选了2个好方法。

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

阅读ElasticSearch Java API,在不需要排序分数和缓存的情况下,可以更好地使用过滤器.我还没弄清楚如何使用FilterBuilders并有以下问题:

可以FilterBuilders单独使用来搜索吗?

或者他们总是必须使用Query?(如果是真的,有人可以列举一个例子吗?)

浏览文档,如果我想根据字段值执行搜索并想使用FilterBuilders,我该如何实现?(使用AndFilterBuilderTermFilterBuilderInFilterBuilder?我不清楚它们之间的差异.)

对于第3个问题,我实际上使用查询和使用过滤器进行了测试,如下所示.当我尝试使用搜索时,我得到了空结果(没有行)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"有效.随着这个问题的解决.我还有以下问题:

在什么情况下,过滤器与查询一起使用?这有什么用途?

之间的区别InFilter,TermFilterMatchAllFilter.任何插图都会有帮助.

javanna.. 11

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

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

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

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

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

MatchAllFilter:匹配你的所有文件,而不是我说的那么有用

TermFilter:筛选包含术语(未分析)的字段的文档

AndFilter:复合过滤器用于放入和两个或多个过滤器

不知道你的意思InFilterBuilder,找不到任何具有此名称的过滤器.

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



1> javanna..:

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

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

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

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

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

MatchAllFilter:匹配你的所有文件,而不是我说的那么有用

TermFilter:筛选包含术语(未分析)的字段的文档

AndFilter:复合过滤器用于放入和两个或多个过滤器

不知道你的意思InFilterBuilder,找不到任何具有此名称的过滤器.

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



2> Geert-Jan..:

附加@javanna说的话:

过滤器可以通过多种方式定义,这可能会产生很多混乱:

独立的(带有必需的查询,例如,match_all如果您只需要过滤器)(http://www.elasticsearch.org/guide/reference/api/search/filter/)

或作为过滤查询的一部分(http://www.elasticsearch.org/guide/reference/query-dsl/filtered-query/)

你可能会问的有什么不同.事实上,你可以用两种方式构建完全相同的逻辑.

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

推荐阅读
谢谢巷议
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有