如何构建动态查询elasticsearch

时间:2016-04-13 13:07:39

标签: java elasticsearch

我想使用html表单中的搜索条件为elasticsearch构建一个查询。我在html页面上有几个输入字段。例如,如果用户填写其中两个字段,我可以写:

    BoolQueryBuilder query =  QueryBuilders.boolQuery()
                                .must(QueryBuilders.termQuery("archivo", "archivo1"))
                                .must(QueryBuilders.termQuery("nombre", "documento1"));  

但是......如果用户填写了我可能拥有的三个字段,该怎么办:

    BoolQueryBuilder query =  QueryBuilders.boolQuery()
                        .must(QueryBuilders.termQuery("archivo", "archivo1"))
                        .must(QueryBuilders.termQuery("nombre", "documento1"))
                        .must(QueryBuilders.termQuery("third", "test"));

有没有办法让dinamicall构建这种查询?

1 个答案:

答案 0 :(得分:6)

BoolQueryBuilder.must()添加一个谓词,它不会取代之前的谓词。

因此,假设字段archivo的值位于变量inputArchivo中,依此类推,您可以检查字段是否已填充,然后添加谓词:

 BoolQueryBuilder query = QueryBuilders.boolQuery();
 if(inputArchivo != null && !inputArchivo.isEmpty()) {
   query.must(QueryBuilders.termQuery("archivo", inputArchivo));
 }

 if(inputNombre != null && !inputNombre.isEmpty()) {
   query.must(QueryBuilders.termQuery("nombre", inputNombre));
 }

 if(inputThird != null && !inputThird.isEmpty()) {
   query.must(QueryBuilders.termQuery("third", inputThird));
 }

然而如果您不知道会出现什么术语,您可以使用以下值迭代HashMap:

for (Map.Entry<String, Object> entry : map.entrySet()) {
    query.must(QueryBuilders.termQuery(entry.getKey, entry.getValue))
}