当前位置: 首页 > 面试题库 >

ElasticSearch-使用FilterBuilders

栾瑞
2023-03-14
问题内容

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

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

  • 可以FilterBuilders单独使用进行搜索吗?
  • 还是必须始终将它们与一起使用Query?(如果为true,请问有人可以列举一个例子吗?)
  • 查看文档,如果我想基于字段值执行搜索并想使用FilterBuilders,该如何实现?(使用AndFilterBuilderTermFilterBuilderInFilterBuilder?我不清楚它们之间的区别。)

对于第三个问题,我实际上通过使用查询和过滤器的搜索对它进行了测试,如下所示。尝试使用进行搜索时,结果为空(无行)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”是可行的。这个问题解决了。我仍然有以下问题:

  • 在什么情况下,查询会使用过滤器?这将达到什么目的?
  • 之间的区别InFilterTermFilterMatchAllFilter。任何插图都将有所帮助。

问题答案:

正确,您应该使用过滤器来排除执行查询时甚至不考虑的文档。筛选器速度更快,因为它们不涉及任何评分,并且也可以缓存。

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

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

如果要在索引时保持“
TX”术语不变,则可以更改映射,也可以将字段设置为not_analyzed仅作为单个标记。否则,您可以更改过滤器,您可能希望查看已分析的查询,以便以与索引内容相同的方式来分析您的查询。

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

  • MatchAllFilter:匹配您所有的文档,我不会说那么有用
  • TermFilter:过滤具有包含术语(未分析)的字段的文档
  • AndFilter:用于放入的复合过滤器和两个或多个过滤器

不知道您的意思是InFilterBuilder,找不到任何使用此名称的过滤器。

该查询通常包含用户在文本搜索框中键入的内容。过滤器是优化搜索的更多方式,例如单击构面条目。因此,您仍然需要查询加上一个或多个过滤器。



 类似资料:
  • Elasticsearch 作为一个 Java 应用,本身的部署已经非常简单了。不过作为生产环境,还是有必要采用一些更标准化的方式进行集群的管理。Elasticsearch 官方提供并推荐使用 Puppet 方式部署和管理。其 Puppet 模块源码地址见: https://github.com/elastic/puppet-elasticsearch 安装方法 和其他标准 Puppet Modu

  • 我已经在我的Windows7机器上本地安装了Elasticsearch。它工作正常,我可以用邮递员查询它。使用Postman,我还创建了一个名为cmstest的索引。这有一个名为ZDSF的表。如果获取该索引的映射(http://localhost:9200/cmstest/_mapping),我将得到以下内容: 我可以邮寄条目到这个表以及使用邮递员。 现在,我正试图从我的.NET 4.5应用程序中

  • 1.bean注入方式 @Autowired private ElasticsearchTemplate elasticsearchTemplate; elasticsearchTemplate 方法如下: /** * Create an index for given indexName */ public boolean createIndex(String indexName) /**

  • 问题内容: 我在让NEST的DeleteByQuery方法工作时遇到了一些困难。 很简单,查询永远找不到要删除的内容,我也不知道为什么。我正在使用相同的查询来返回记录(使用搜索),并且一切正常。 我只是刚刚开始使用NEST,所以我确定这是一个非常简单的问题,而且我有点昏暗! 任何帮助/建议,不胜感激。 问题答案: 的是上的.NET方法支票是否相等。 如果您更改对它的呼叫,则应该可以使用。

  • 本文向大家介绍为什么要使用Elasticsearch?相关面试题,主要包含被问及为什么要使用Elasticsearch?时的应答技巧和注意事项,需要的朋友参考一下   因为在我们商城中的数据,将来会非常多,所以采用以往的模糊查询,模糊查询前置配置,会放弃索引,导致商品查询是全表扫面,在百万级别的数据库中,效率非常低下,而我们使用ES做一个全文索引,我们将经常查询的商品的某些字段,比如说商品名,描述

  • 我想在我的java应用程序中获得聚合。 首先,我用curl构造了REST查询。它看起来像: 结果和我预期的一样 之后我在java中创建了一些代码 问题是: 如何获取当前bucket项的“contract\u sum”聚合值? 当我在IntelliJ Idea中使用调试工具时,它似乎可以 请帮助我的代码示例。