繁体   English   中英

如何在 Elasticsearch 的无痛脚本中使用 Java 的 ArrayList class?

[英]How can i use Java's ArrayList class in painless script of Elasticsearch?

我想为elasticsearch中的 script_score 编写一个脚本。

在 Painless Documentation中,“共享 api 参考”下有一个 java 类列表。

GET hockey/_search
{
  "explain": true, 
  "query": {
    "match_all": {}
  },
  "script_fields": {
    "total_goals": {
      "script": {
        "lang": "painless",
        "source": """

          int[] arr = new int[3];
          arr[0] = 1;
          arr[1] = 2;
          arr[2] = 3;
          return arr;

        """,
        "params":{
          "last" : "any parameters required"
        }

      }
    }
  }
}

上面的脚本按预期工作。 但我想改用Java的 ArrayList 或其他一些 Class 。

GET hockey/_search
{
  "explain": true, 
  "query": {
    "match_all": {}
  },
  "script_fields": {
    "total_goals": {
      "script": {
        "lang": "painless",
        "source": """
          ArrayList<Integer> al = new ArrayList<Integer>();
          al.add(1);
          al.add(2);
          return al;

        """,
        "params":{
          "last" : "any parameters required"
        }

      }
    }
  }
}

这会引发以下错误。

{
  "error" : {
    "root_cause" : [
      {
        "type" : "script_exception",
        "reason" : "compile error",
        "script_stack" : [
          "\n          ArrayList<Integer> al = new ArrayL ...",
          "                    ^---- HERE"
        ],
        "script" : "\n          ArrayList<Integer> al = new ArrayList<Integer>();\n          al.add(1);\n          al.add(2);\n          return al;\n          \n        ",
        "lang" : "painless"
      }
    ],
    "type" : "search_phase_execution_exception",
    "reason" : "all shards failed",
    "phase" : "query",
    "grouped" : true,
    "failed_shards" : [
      {
        "shard" : 0,
        "index" : "hockey",
        "node" : "UIMgEAZNRzmIpRGyQtNk9g",
        "reason" : {
          "type" : "script_exception",
          "reason" : "compile error",
          "script_stack" : [
            "\n          ArrayList<Integer> al = new ArrayL ...",
            "                    ^---- HERE"
          ],
          "script" : "\n          ArrayList<Integer> al = new ArrayList<Integer>();\n          al.add(1);\n          al.add(2);\n          return al;\n          \n        ",
          "lang" : "painless",
          "caused_by" : {
            "type" : "illegal_argument_exception",
            "reason" : "invalid sequence of tokens near ['<'].",
            "caused_by" : {
              "type" : "no_viable_alt_exception",
              "reason" : null
            }
          }
        }
      }
    ]
  },
  "status" : 400
}

如果可以使用 ArrayList class 那么,

我必须从 java.util 导入它吗?

您可以使用ArrayList al = new ArrayList(); 甚至简单地def al = new ArrayList(); 文档中的更多信息。

仅供参考:您可以使用Debug.explain(al); 检查什么是什么!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM