首页 > 解决方案 > 在elasticsearch中删除嵌套数组

问题描述

我有包含以下格式的嵌套表的文档:

{
"dataId": "dataIdentifier",
"versionId": "versionIdentifier",
"items": [
{
"obj1": "value1",
"obj2": "value2",
"obj3": "value3",
 },
 {
"obj1": "value4",
"obj2": "value5",
"obj3": "value6"
}, 
{
"obj1": "value7",
"obj2": "value8",
"obj3": "value9" 
}        
]
}

“项目”是嵌套类型。我想删除给定的“项目”中的一个元素,而不是其中一个对象具有一定的值。例如它将是:

if (obj1 == "value4" & dataId == "dataIdentifier" & versionId == versionIdentifier) :
    DELETE TABLE ENTRY 

在这种情况下,我想删除“项目”的第二个条目。我试图用update_by_query 来做,我的尝试是:

q = {
   "query": {
    "match_all": {}
    }
},
"script": {
    "lang" : "painless",
    "inline" : {if (ctx._source.dataId == item.dataId && ctx._source.versionId == item.versionId && ctx._source.items.obj1 == item.obj1) {ctx._source.items.remove()}}",
    "params" : {
        'dataFrame': [{
            "dataId" : 'myDataIdList',
            "versionId" : 'myVersionId',
            "obj1" : 'myValue'
            } ]
    }
 }    
}

es.update_by_query(index=myindex, body=q)

但我不知道如何在“ctx._source.items.remove()”参数中指定相关条目。我查看了 Elasticsearch 文档,但找不到我想要的东西。任何帮助将不胜感激。

标签: pythonelasticsearchelasticsearch-py

解决方案


通过查询更新,您不能删除“一个字段”,您可以替换它,为此,您可以用其他两个值更新它您想要维护或删除文档并用这两个值索引一个新的


推荐阅读