1

首先,这是取自文档

传递一个字符串数组

GET /_search/template
{
  "template": {
    "query": {
      "terms": {
        "status": [
          "{{#status}}",
          "{{.}}",
          "{{/status}}"
        ]
      }
    }
  },
  "params": {
    "status": [ "pending", "published" ]
  }
}

呈现为:

{
"query": {
  "terms": {
    "status": [ "pending", "published" ]
  }
}

但是,在我的场景中,我完成了完全相同的模板(至少我是这么认为的),但它对我产生的输出略有不同:

.."filter" : {
  "bool" : {
    "must" : [{
        "terms" : {
          "myTerms" : [
            "{{#myTerms}}",
            "{{.}}",
            "{{/myTerms}}"
          ],
          "_cache" : true
        }
      }
    ]
  }
}..

我后来这样称呼它:

GET /passport/_search/template
{
    "template": {
        "id": "myTemplate" 
    },
    "params": {
        "myTerms": ["1", "2"]
    }
}

然而它被渲染为:

.."myTerms" : ["", "1", "2", ""]..

这不是问题,但 myTerms 存储为整数,我想保持这种方式(但如果只有这是解决方案,那么很好,我可以忍受),但是查询会抛出它不能的异常将 "" 转换为整数类型,这是预期的行为

NumberFormatException[对于输入字符串:\"\"]

我应该如何处理?我不想将我的模板存储为文件,我更喜欢它们被索引。

这个 SO 问题很有希望:将整数数组传递给 ElasticSeach 模板,但不清楚,答案并没有解决我的问题(我不允许这样存储我的模板)。

使用的 Elasticsearch 版本:1.6.0

请指教。

4

1 回答 1

2

我以前见过这个要求,这个解决方案看起来很老套,但它确实有效。基本上,模板中的逗号是问题,因为 Mustache 将遍历数组,并且对于数组中的每个元素,都会将元素 - {{.}}- 以及您指定的逗号{{#myTerms}}放在and{{/myTerms}}中。

而且,在你的情况下,你不应该使用双引号-"{{.}}"因为元素本身将被双引号包围。这就是您在结果中看到"1"的原因。但是,如果您想匹配应该是数字列表而不是字符串的数字。

所以,首先,去掉双引号。这意味着,用双引号将模板括起来,并转义应该在最终结果中出现的任何双引号(通过查看下面的示例,您很快就会理解)。

其次,hacky部分是模拟结果中的逗号并跳过最后一个逗号。意思是,1,2,3,不应该包含最后一个逗号。解决方案是将参数作为元组列表提供 - 元组的一个元素是值本身,另一个元素是布尔值:[{"value":1,"comma":true},{"value":2,"comma":true},{"value":4}]。如果comma是,true则 Mustache 应放置,,否则不应放置(这种情况适用于数组中的最后一个元素)。

POST /_search/template/myTemplate
{"template":"{\"filter\":{\"bool\":{\"must\":[{\"terms\":{\"myTerms\":[{{#myTerms}}{{value}}{{#comma}},{{/comma}}{{/myTerms}}],\"_cache\":true}}]}}}"}

这就是你应该如何传递参数:

{
  "template": {
    "id": "myTemplate"
  },
  "params": {
    "myTerms": [{"value":1,"comma":true},{"value":2,"comma":true},{"value":4}]
  }
}

这样做是为了生成这样的东西:

{
  "filter": {
    "bool": {
      "must": [
        {
          "terms": {
            "myTerms": [1,2,4],
            "_cache": true
          }
        }
      ]
    }
  }
}
于 2015-07-09T12:36:57.043 回答