弹性搜索从嵌套对象中删除元素
Elastic Search Remove Elements From Nested Object
我在弹性搜索中创建了一个带有嵌套类型字段的索引。并将文档添加到索引中。现在我想使用 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"
}
}]
}
}
}
我在弹性搜索中创建了一个带有嵌套类型字段的索引。并将文档添加到索引中。现在我想使用 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"
}
}]
}
}
}