一尘不染

Elasticsearch是否保持多值字段的顺序?

elasticsearch

Elasticsearch是否保持多值字段的顺序?

即,如果我在字段中输入了以下值:

{
    "values": ["one", "two", "three"],
    "values_original": ["1", "2", "3"]
}

(鉴于未分析字段)

我是否可以确定列表的内容将始终按照与放置列表相同的顺序返回?

在上面的示例中,我想确保“值”中第一个位置的“一个”将始终与“ values_original”等中的“ 1”相对应。

我也可以将其保留为嵌套对象,即

{
    "values": [
        {"original": "1", "new": "one"}, 
        {"original":"2", "new":"two"},
        {"original":"3","new":"three"}
    ]
}

但我想避免开销。

如果可以保证保留多值字段中的值顺序,那么我保留两个并行多值字段的方法将起作用。


阅读 462

收藏
2020-06-22

共1个答案

一尘不染

Elasticsearch-
权威指南
说:

当您从Elasticsearch取回文档时,所有数组的顺序都与索引该文档时的顺序相同。您返回的_source字段包含与索引相同的JSON文档。

但是,数组被索引(可搜索)为无序的多值字段。在搜索时,您不能引用“第一个元素”或“最后一个元素”。而是将数组视为一袋值。

因此,对于存储的字段,似乎保留了顺序,对于索引的字段,则没有保留。

2020-06-22