When creating the mappings for an index that can search through multiple books, is it preferable to use nested mappings like below, or using documents with a parent-child relati
If you use the nested
type, everything will be contained in the same _source
document, which for big books can be quite a mouthful.
Whereas if you use parent/child docs for each chapters and/or sections, you might end up with smaller chunks which are more chewable...
As always, it heavily depends on the queries you will want to make, so you should first think about all the use cases you will want to support and then you'll be better armed to figure out which approach is best.
There's another approach which uses neither nested nor parent/child, and which simply involves denormalization. Concretely, you pick the smallest "entity" you want to consider, e.g. a section, and then simply create standalone documents for each section. In those section documents, you'd have fields for the book title, author, chapter title, section title, etc.
You can try each approach in their own index and see how it goes for your use cases.