过滤条件查询不起作用-Elasticseach和Java API

时间:2018-12-12 09:02:25

标签: java elasticsearch elasticsearch-5

我是stackoverflow的新手

这是我的问题

我想在ES中发出一个请求,该请求首先执行必须,然后执行过滤器。在sql中,其外观应与此类似

SELECT * FROM table WHERE name = "the_name" AND type IN ("type1", "type2")

这是我对这种情况的实施方式

@Override
public List<Example> findByName(String pattern, String... types) {
    // Prepare query
    QueryBuilder queryBuilder = QueryBuilders.boolQuery()
            .must(QueryBuilders.termQuery("name", pattern))
            .filter(QueryBuilders.termsQuery("type", types));

    // Execute query    
    return new ArrayList<>(this.elasticsearchQuery.findAgainstFields(Example.class, queryBuilder));
}

接下来,我对方法 findAgainstFields

的实现
@SuppressWarnings("unchecked")
@Override
public <T> List<T> findAgainstFields(Class<?> t, QueryBuilder query) {
    NativeSearchQueryBuilder nativeSearchQueryBuilder = new NativeSearchQueryBuilder();

    NativeSearchQuery nativeSearchQuery = nativeSearchQueryBuilder
            .withIndices("my_indice")
            .withTypes(t.getSimpleName())
            .withSort(new ScoreSortBuilder().order(SortOrder.DESC))
            .withQuery(query)
            .withPageable(PageRequest.of(0, 5)).build();

    // Execute query
    return (List<T>) this.elasticsearchTemplate.queryForList(nativeSearchQuery, t);
}

当我运行项目时,此方法( findByName )返回一个空数组。但是,当我删除.filter(QueryBuilders.termsQuery("type", types))时,我得到了结果。那么,我哪一部分错了?

预先感谢

ps:我使用ES 5.5和Java 8 oracle

更新

ES查询是这样:

{
  "bool" : {
    "must" : [
      {
        "term" : {
          "name" : {
            "value" : "eso",
            "boost" : 1.0
          }
        }
      }
    ],
    "filter" : [
      {
        "terms" : {
          "type" : [
            "Society",
            "Institut"
          ],
          "boost" : 1.0
        }
      }
    ],
    "disable_coord" : false,
    "adjust_pure_negative" : true,
    "boost" : 1.0
  }
}

因此,在这里,我尝试查找名称为 eso 且具有 type 且可能是 Society 的数据。或研究所

1 个答案:

答案 0 :(得分:0)

问题出在映射文件中而不是Java源代码上。 因此我通过将属性 type 的类型更改为关键字(之前是 text )来更新文件,并且一切正常。