使用 Java 高级 REST 客户端动态更改弹性文档

问题描述

我的主要目的是通过 Java 高级 REST 客户端更新 ElasticSearch 中的现有文档。

对于这个任务,我使用了 UpdateByQueryRequest,并设置了一个修改相关文档的脚本。

我的问题是,是否可以动态设置字段及其新值:

public Script buildUpdateQueryScript(Map<String,String> updatedValues) {

        String script = "";
       
        updatedFields.forEach((key,value) -> script.concat("ctx._source.").concat(key).concat(" = ").concat(value) );


        return new Script(
            ScriptType.INLINE,"painless",script,Collections.emptyMap()
        );

    }

例如,如果我的 Map 包含一个元素 ("keyOne","valueOne"),那么 script 将如下所示:

"ctx._source.keyOne = valueOne"

这当然行不通,我想知道这是否可以动态构建脚本,如果可以,正确的方法是什么?

解决方法

我已经找到了这个问题的答案,我会把它贴在这里,这样你就会有类似问题的参考:

Map<String,Object> params = new HashMap<>();
        params.put("keyOne","valueOne");
        params.put("keyTwo","valueTwo");


for (String key : params.keySet()) {
            script = script + "ctx._source." + key + " = params." + key + ";";
        }

return new Script(
            ScriptType.INLINE,"painless",script,params
        );