Можете просто да съхранявате типовете и подтиповете в масив като този:
doc1 = {
"_type": ["animal"],
"name": ...
}
doc2 = {
"_type": ["animal","dog"],
"name": ...,
"barkFile": ...
}
doc3 = {
"_type": ["animal","dog","poodle"],
"name": ...,
"barkFile": ...,
"haircut": ...
}
Използвайки този модел, заявката db.data.find({_type:"dog"})
връща както doc2, така и doc3.