Elastic Search Java API对令牌的多匹配查询前缀查询

时间:2017-02-12 17:17:18

标签: search elasticsearch n-gram

我正在寻找一些方法,我想用Elastic java api中的NativeSearchQueryBuilder搜索我的索引,但我想在搜索时添加以下内容。 索引详情:

  1. 过滤器类型EdgeNgram
  2. 白色空间标记器
  3. 我正在寻找自动完成功能,所以在这里我想在多个字段上应用搜索关键字,但它应该使用前缀来提高性能,我也希望结果需要返回,如果它们达到我指定的页面限制而不是继续搜索索引,即使它找到了足够的结果。

    Ex:“albert einstein”在我的索引中,现在如果我搜索“alb”它应该返回结果,或者如果我搜索“ein”它应该返回结果。

        NativeSearchQueryBuilder sb = new NativeSearchQueryBuilder()
                .withIndices(Constants.ES_INDEX_NAME)
                //.withPageable(pageable)
                .withSourceFilter(new FetchSourceFilterBuilder().withIncludes("id").build())
                .withTypes(Constants.USERS_TYPE)
                .withQuery(multiMatchQuery("alb", new String[]{"userFirstName","userLastName","userMobile", "userEmail"}))
                .withFilter(boolQuery()
                        .must(termQuery("userCityName", "Chicago")));
    

    请有人帮我解决这个问题,如何在我的Multimatch Query构建器中添加前缀和限制。

1 个答案:

答案 0 :(得分:1)

您要找的是match_phrase_prefix

int limit = 100; //Set your limit

NativeSearchQueryBuilder sb = new NativeSearchQueryBuilder()
            .withIndices(Constants.ES_INDEX_NAME)
            .withPageable(new PageRequest(0, limit))
            .withSourceFilter(new FetchSourceFilterBuilder().withIncludes("id").build())
            .withTypes(Constants.USERS_TYPE)
            .withQuery(QueryBuilders.multiMatchQuery("alb", "userFirstName","userLastName","userMobile", "userEmail")
                                    .type(MatchQueryBuilder.Type.PHRASE_PREFIX))
            .withFilter(boolQuery()
                    .must(termQuery("userCityName", "Chicago")));
相关问题