我的索引已经填满了许多文件。
索引中的所有文档都有一个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 不做任何事情吗?
找到了,我的字符串字段是一个分析字段,所以我必须使用这样的匹配查询:
POST my_index/_update_by_query
{
"script": {
"inline": "ctx._source.name = 'B'",
"lang": "painless"
},
"query": {
"match": {
"name" : "A"
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8193 次 |
| 最近记录: |