使用Java API在Elasticsearch的所有字段中搜索多个字符串

Kri*_*l P 6 java nosql elasticsearch elasticsearch-plugin

我有一个弹性搜索索引,用户的字段如..."name":"kai""age":"23""location":"Delhi,India""tag":["search","nosql"]等.

我想在用户的所有字段中查询多个字符串(例如.["nosql","delhi"]).是否可以使用Java API?

这是我正在使用的代码示例.(但这与问题无关)它只是为了知道我现在正在使用的对象.

BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery()
                .must(QueryBuilders.matchAllQuery());
        if(location!=null) {
            queryBuilder.must(QueryBuilders.matchQuery("location",location));
        }
        BoolFilterBuilder filerBuilder=FilterBuilders.boolFilter();     
        for(String skill:skills){
            filerBuilder.must(FilterBuilders.rangeFilter("tags."+skill).from(0));
        }
        filerBuilder.must(FilterBuilders.queryFilter(queryBuilder));
        if(age!=null) {
            filerBuilder.must(FilterBuilders.rangeFilter("age").from(age[0]).to(age[1]));
        }
        SearchResponse response = client.prepareSearch("skillbin")
                .setTypes("stackdump")
                .setSearchType(SearchType.QUERY_AND_FETCH)
                .setQuery(queryBuilder)   
                .setPostFilter(filerBuilder)
                .addSort("reputation", SortOrder.DESC)
                .execute()
                .actionGet();
        SearchHits hits=response.getHits(); 
Run Code Online (Sandbox Code Playgroud)

提前致谢.:)

hex*_*nny 8

在Java API中,您可以查询"_all"字段,该字段默认包含文档的所有字段.另一种方法是使用MultiMatchQuery,它更灵活,允许您指定要查询的字段列表.

下面是关于如何访问"_all"字段,以及如何创建一些示例代码MultiMatchQuery使用MultiMatchQueryBuilderQueryBuilders.沿着查询的multiMatchQuery搜索所有字段:

String queryString = "nosql delhi";

String allField = "_all";

MultiMatchQueryBuilder mmqb = QueryBuilders.multiMatchQuery(queryString, allField);
Run Code Online (Sandbox Code Playgroud)


小智 1

如果您使用标准分析器,elasticsearch 默认使用空格标记器对每个单词进行标记。

在这种情况下,您可以使用查询字符串查询进行搜索,您可以在其中添加多个要搜索的字段。此外,查询字符串查询的默认运算符是“OR”。因此,如果您的搜索词是“nosql delhi”(如您的情况),它会被翻译为“nosql OR delhi”并在查询中指定的所有字段中进行搜索。这样您就可以在多个字段中搜索多个术语。

希望有帮助。