弹性搜索从嵌套对象中删除元素

问题描述

我在带有嵌套类型字段的弹性搜索中创建了一个索引。并将文档添加到索引中。现在,我想使用UpdateByQuery从嵌套对象中删除一些符合条件的元素。我已经尝试执行以下查询,但是遇到冲突错误

POST test/_update_by_query
{
    "script": {
        "source": "for(int i= 0; i< ctx._source.address.size(); i++){if(ctx._source.address[i].city == params.city && ctx._source.address[i].state == params.state){ctx._source.address.remove(i)}}","params": {
            "city": "Mumbai","state": "Maharashtra"
        }
    },"query": {
        "bool": {
            "must": [{
                "term": {
                    "uid": "123"
                }
            }]
        }
    }
}

我们有多个文档,其uid为“ 123”还有其他选择可从嵌套对象中删除元素而不会发生冲突错误吗?我如何能解决这个问题,请在这里帮助我。

解决方法

您需要这样做:

POST test/documents/_update_by_query
{
    "script": {
        "source": "ctx._source.address.removeIf(a -> a.city == params.city && a.state == params.state)","params": {
            "city": "Mumbai","state": "Maharashtra"
        }
    },"query": {
        "bool": {
            "must": [{
                "term": {
                    "uid": "123"
                }
            }]
        }
    }
}