是否
可以通过查询别名来请求单个文档的 id,前提是别名中所有索引中的所有键都是唯一的(这是外部保证)?
是的,查询跨多个索引的别名与查询一个索引的工作方式相同。
只需对别名执行此查询:
POST my_alias_name/_search
{
"filter":{
"term":{"_id": "AUwNrOZsm6BwwrmnodbW"}
}
}
编辑:GET操作不是真正的搜索,不能对跨越多个索引的别名完成。因此,以下查询实际上是不允许的:
GET my_alias_name/my_type/AUwNrOZsm6BwwrmnodbW
从 Elasticsearch 5.1 开始,查询如下所示:
GET /my_alias_name/_search/
{
"query": {
"bool": {
"filter": {
"term": {
"_id": "AUwNrOZsm6BwwrmnodbW"
}
}
}
}
}
在 Elasticsearch 8.2 文档之后,您可以使用 GET API 检索单个文档:
GET my-index-000001/_doc/0
7.2 版本的文档建议:
GET /_search
{
"query": {
"ids" : {
"values" : ["1", "4", "100"]
}
}
}
响应应如下所示:
{
"took": 0,
"timed_out": false,
"_shards": {
"total": 2,
"successful": 2,
"skipped": 0,
"failed": 0
},
"hits": {
"total": {
"value": 1,
"relation": "eq"
},
"max_score": 1.0,
"hits": [
{
"_index": "indexwhatever",
"_type": "_doc",
"_id": "anyID",
"_score": 1.0,
"_source": {
"field1": "value1",
"field2": "value2"
}
}
]
}
}
如果你想找到一个带有 curl 的内部 id 的文档:
curl -X GET 'localhost:9200/_search?q=id:42&pretty'