ElasticSearch 6.x 父子文档[join]分析
Posted yucy
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ElasticSearch 6.x 父子文档[join]分析相关的知识,希望对你有一定的参考价值。
ES6.0以后,索引的type只能有一个,使得父子结构变的不那么清晰,毕竟对于java开发者来说,index->db,type->table的结构比较容易理解。
按照官方的说明,之前一个索引有多个type,如果有一个相同的字段在不同的type中出现,在es底层其实是按照一个field来进行存储的,这很具有迷惑性,容易造成误解。所以6.0以后,所有的字段都在索引的_doc【默认type】中集中定义。假设索引中会有parent和child两个类型的文档,那么可能parent引用了abcd字段,child引用了aef字段,各取所需。
目前我用的es版本为6.3,父子结构需要用join字段来定义,关系的映射用relations字段来指定。
一个索引中只能有一个join类型字段,如果定义一个以上的join字段,会报错:Field [_parent_join] is defined twice in [_doc]
join字段中的relations集合,建好索引之后,可以增加映射,或者给原有的映射添加child,但是不能删除原有的映射。
比如,原有的relations定义为:
"myJoin": { "type": "join", "eager_global_ordinals": true, "relations": { "parent_a": child_a1 } }
现在通过updateMapping API增加一条映射parent_b,原有的映射增加了child_a2和child_a3:
"myJoin": { "type": "join", "eager_global_ordinals": true, "relations": { "parent_a": [ "child_a1", "child_a2", "child_a3" ], "parent_b": "child_b" } }
以上是关于ElasticSearch 6.x 父子文档[join]分析的主要内容,如果未能解决你的问题,请参考以下文章
干货 | Elasticsearch Nested类型深入详解
是否可以更新 ElasticSearch 6.x 索引中现有字段映射的“存储”值?