gpt4 book ai didi

php - Elasticsearch:使用无痛脚本获取对象索引

转载 作者:行者123 更新时间:2023-12-03 00:06:55 25 4
gpt4 key购买 nike

我有一个嵌套类型,我需要获取特定对象的索引才能执行更新:

{
"_index": "asset_en_v1",
"_type": "note",
"_id": "23217",
"_version": 24,
"found": true,
"_source": {
"user_id": "11",
"title": "Title",
"note": "Note.",
"creation": "2017-05-31T21:36:01",
"modification": "2017-05-31T21:36:01",
"links": [
{
"note_link_id": "7310",
"user_id": "11",
"creation": "2017-06-01T14:41:50",
"modification": "2019-06-01T14:42:00",
"comment": "Comment goes here."
},
{
"note_link_id": "7311",
"user_id": "11",
"creation": "2017-06-01T14:42:42",
"modification": "2019-06-01T14:42:00",
"comment": "Yep..."
},
{
"note_link_id": "7312",
"user_id": "11",
"creation": "2017-06-01T15:33:55",
"modification": "2017-06-01T15:34:00",
"comment": "Jumo."
}
]
}
}

到目前为止,我已经在Painless脚本中创建了一个 _update语句,几乎可以完成这项工作,但是我一直在努力寻找匹配项:
{
"script": {
"lang": "painless",
"inline": "def note_link_id = 7311; def links = ctx._source.links; for (int i = 0; i < links.length; ++i) { if (links[i].note_link_id == note_link_id) { ctx._source.links[note_link_id].comment = params.comment; ctx._source.links[note_link_id].modification = params.modification } }",
"params": {
"modification": "2019-06-01T14:42:00",
"comment": "QWERTY!"
}
}
}

在这里, links[i].note_link_id == note_link_id不匹配。

有任何想法吗?

最佳答案

在您的内联脚本中,它应该是i ++,而不是++ i

def note_link_id = 7311; 
def links = ctx._source.links;
for (int i = 0; i < links.length; i++) //Note i++, instead of ++i
{
if (links[i].note_link_id == note_link_id)
{
ctx._source.links[note_link_id].comment = params.comment;
ctx._source.links[note_link_id].modification = params.modification
}
}

关于php - Elasticsearch:使用无痛脚本获取对象索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44331432/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com