3

我们正在设置 Amazon Elasticsearch Service(运行 Elasticsearch 2.3 版)。

我们有不同类型的数据(我目前将其视为同一索引中的不同文档类型)。

我们在需要内联自动完成功能的应用程序中有一个通用搜索,即完成建议器返回来自所有不同数据(文档)类型的命中。那怎么设置?

查询建议者时,您必须指定一个索引,这就是我想将所有数据保存在同一个索引中的原因。根据文档,完成建议器会考虑索引中的所有文档。

为第一个文档类型设置完成建议非常简单,并且效果很好。但是,据我所知,您在查询时指定了一个建议字段。如果不是因为我们在为第二种文档类型设置映射时收到的错误消息,那就太好了:

类型:非法参数异常原因:“[建议] 被定义为映射 [name_of_document_type] 中的对象,但此名称已用于其他类型的字段”

写这个问题我发现可以在一个建议查询中指定多个建议者。也许这就是我们必须解决的问题?(即从 Y 个建议者那里得到 X 个结果,我们比较分数以获得我们想要呈现给用户的 1 个建议。)

4

1 回答 1

1

Elasticsearch(与许多数据存储一样)良好数据设计的核心原则之一是优化数据存储以便于阅读。通常,这意味着拥抱重复

考虑到这一点,我建议使用一个单独的自动完成索引,其中包含专门为建议查询设计的映射。

每当您插入或写入其他文档之一时,将其映射到您的自动完成类型并同时在自动完成索引中添加或更新它(或者,根据它需要的最新程度,创建一个离线过程更新您的自动完成索引,例如每天)。

然后,当您进行建议查询时,您可以只使用自动完成索引,而不必担心处理具有不同字段的不同类型的文档。

于 2016-10-12T12:19:48.470 回答