我目前使用的是Elastic4s v5.0,它仍然使用多字段类型以多种方式对字段进行索引。
elasticClient.execute(createIndex("foo") mappings (
mapping("bar").as(
multiField("baz").as(
textField("baz") analyzer myAnalyzer,
textField("original") index NotAnalyzed
)
)
)但是,我得到以下错误:
No handler for type [multi_field] declared on field []这里的答案是field和文档,https://www.elastic.co/guide/en/elasticsearch/reference/current/multi-fields.html说要使用“字段”,但是我在elastic4s中找不到如何做到这一点。
发布于 2017-03-02 23:34:48
在弹性搜索中,任何多字段都有一个主字段,类似于父字段,然后它有第二个字段。主字段(顺便说一下,主字段和次要字段是我的术语),是用a访问的,次要字段被访问为a.b、a.c等等。
这可能不是你首先想象的一个多字段的样子,因为你可能只是认为有a,b,c作为兄弟姐妹,就像一种序列。所以了解这一点是值得的。
在elastic4s中,您可以在任何想要的字段上使用.fields,然后这些字段将与父字段组合成为多个字段。所以你的例子会被改写。
client.execute {
createIndex("foo").mappings(
mapping("bar").fields(
textField("baz").fields(
textField("inner1") analyzer PatternAnalyzer,
textField("inner2") index NotAnalyzed
)
)
)
}注意,as是fields的别名,我认为fields更易读,所以我在这里使用了它。
https://stackoverflow.com/questions/42561918
复制相似问题