| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 | [[mapping-parent-field]]=== `_parent`TIP: It is highly recommend to reindex all indices with `_parent` field created before version 2.x.     The reason for this is to gain from all the optimizations added with the 2.0 release.The parent field mapping is defined on a child mapping, and points tothe parent type this child relates to. For example, in case of a `blog`type and a `blog_tag` type child document, the mapping for `blog_tag`should be:[source,js]--------------------------------------------------{    "blog_tag" : {        "_parent" : {            "type" : "blog"        }    }}--------------------------------------------------The mapping is automatically stored and indexed (meaning it can besearched on using the `_parent` field notation).==== LimitationsThe `_parent.type` setting can only point to a type that doesn't exist yet.This means that a type can't become a parent type after is has been created.The `parent.type` setting can't point to itself. This means self referentialparent/child isn't supported.==== Global ordinalsParent-child uses <<global-ordinals,global ordinals>> to speed up joins and global ordinals need to be rebuilt after any change to a shard.The more parent id values are stored in a shard, the longer it takes to rebuild global ordinals for the `_parent` field.Global ordinals, by default, are built lazily: the first parent-child query or aggregation after a refresh will trigger building of global ordinals.This can introduce a significant latency spike for your users. You can use <<fielddata-loading,eager_global_ordinals>> to shift the cost of building global ordinalsfrom query time to refresh time, by mapping the _parent field as follows:==== Memory usageThe only on heap memory used by parent/child is the global ordinals for the `_parent` field.How much memory is used for the global ordianls for the `_parent` field in the fielddata cachecan be checked via the <<indices-stats,indices stats>> or <<cluster-nodes-stats,nodes stats>>APIS, eg:[source,js]--------------------------------------------------curl -XGET "http://localhost:9200/_stats/fielddata?pretty&human&fielddata_fields=_parent"--------------------------------------------------
 |