将Elastic Search字段转换为数组
在elasticsearch中,如果您的文档具有预先存在的数组
"movies": [ "Back to the Future"
]
然后您更新它以添加更多类似的电影
{ "script" : "ctx._source.movies += tag",
"params" : {
"tag" : "Pulp Fiction"
}
}
然后将值添加到该字段。效果很好…但是,如果该领域并非一开始就很麻烦,而是看起来像这样,该怎么办
"movies": "Back to the Future"
如果运行相同的脚本,将得到以下结果
"movies":"Back to the FuturePulpFiction"
因此,我的问题是如何利用这个现有字段并将其“转换”为数组,以告诉elasticsearch我想将其视为数组?
回答:
您可以改用此脚本。它检查是否movies
为数组,如果不是,则创建一个
{ "script" : "if (ctx._source.movies.getClass().isArray()) { ctx._source.movies += tag } else { ctx._source.movies = [ctx._source.movies, tag] }",
"params" : {
"tag" : "Pulp Fiction"
}
}
另一种较短的方法是始终分配一个数组,然后使用Groovy的Collection.flatten()
方法对其进行“展平”
{ "script" : "ctx._source.movies = [ctx._source.movies, tag].flatten()",
"params" : {
"tag" : "Pulp Fiction"
}
}
以上是 将Elastic Search字段转换为数组 的全部内容, 来源链接: utcz.com/qa/427808.html