如何使用 elasticsearch _update_by_query 更新字符串字段?

sin*_*ge3 4 elasticsearch

我的索引已经填满了许多文件。
索引中的所有文档都有一个name字符串字段。
我想查询和更新所有具有并将其name = A设置为name = B.

为清楚起见,在 SQL 中,它类似于:
UPDATE FROM table SET name = 'B' WHERE name = 'A';

使用elasticsearch API,根据文档:https : //www.elastic.co/guide/en/elasticsearch/reference/current/docs-update-by-query.html

我试过这个查询:

POST my_index/_update_by_query
{
  "script": {
    "inline": "ctx._source.name = 'B'",
    "lang": "painless"
  },
  "query": {
    "term": {
      "name" : "A"
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

然而,它只是返回没有任何修改。我仍然可以找到 name=A 的文档,所以它们没有被编辑。

{
  "took": 1,
  "timed_out": false,
  "total": 0,
  "updated": 0,
  "deleted": 0,
  "batches": 0,
  "version_conflicts": 0,
  "noops": 0,
  "retries": {
    "bulk": 0,
    "search": 0
  },
  "throttled_millis": 0,
  "requests_per_second": -1,
  "throttled_until_millis": 0,
  "failures": []
}
Run Code Online (Sandbox Code Playgroud)

知道为什么我的 _update_by_query 不做任何事情吗?

sin*_*ge3 6

找到了,我的字符串字段是一个分析字段,所以我必须使用这样的匹配查询:

POST my_index/_update_by_query
{
  "script": {
    "inline": "ctx._source.name = 'B'",
    "lang": "painless"
  },
  "query": {
    "match": {
      "name" : "A"
    }
  }
}
Run Code Online (Sandbox Code Playgroud)