Elasticsearch 按查询更新 - 仅更新具有最小时间戳的文档

问题描述

我是 elasticsearch 的新手,我正在尝试从我的索引中获取一个文档并更新它的对象列表。

我尝试了几个查询,例如:

POST localhost:9200/test-index/_update_by_query

{
 "size":1,"sort": [{"timestamp":"asc"}],"script": {
      "inline": "ctx._source.addresses.add(params.address)","params" : {
           "address" :{
                  "street": "Yemen Road","number": 15,"county": "Yemen"
              }
        }
    }
}

但这会更新我的所有文档。 最快的方法是什么?

先谢谢你!

解决方法

我从 elasticsearch 社区得到了以下答案:

按查询更新不支持大小。您需要先使用大小和排序运行查询,然后在该单个文档上使用更新 API。