我在具有嵌套类型字段的 flex 搜索中创建了一个索引。并将文档添加到索引中。现在,我想使用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"
                }
            }]
        }
    }
}

关于elasticsearch - Elasticsearch 从嵌套对象中删除元素,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/63485888/

10-15 23:18