Em primeiro lugar, bem-vindo ao MongoDB!
A coisa a lembrar é que o MongoDB emprega uma abordagem "NoSQL" para armazenamento de dados, então elimine os pensamentos de seleções, junções, etc. de sua mente. A forma como ele armazena seus dados é na forma de documentos e coleções, o que permite um meio dinâmico de adicionar e obter os dados de seus locais de armazenamento.
Dito isso, para entender o conceito por trás do parâmetro $ unwind, primeiro você deve entender o que o caso de uso que você está tentando citar está dizendo. O documento de exemplo de mongodb.org é o seguinte:
{
title : "this is my title" ,
author : "bob" ,
posted : new Date () ,
pageViews : 5 ,
tags : [ "fun" , "good" , "fun" ] ,
comments : [
{ author :"joe" , text : "this is cool" } ,
{ author :"sam" , text : "this is bad" }
],
other : { foo : 5 }
}
Observe como as tags são na verdade um array de 3 itens, neste caso sendo "divertido", "bom" e "divertido".
O que $ unfind faz é permitir que você retire um documento para cada elemento e retorne o documento resultante. Pensando nisso em uma abordagem clássica, seria o equivalente a "para cada item na matriz de tags, retorne um documento com apenas aquele item".
Assim, o resultado da execução do seguinte:
db.article.aggregate(
{ $project : {
author : 1 ,
title : 1 ,
tags : 1
}},
{ $unwind : "$tags" }
);
retornaria os seguintes documentos:
{
"result" : [
{
"_id" : ObjectId("4e6e4ef557b77501a49233f6"),
"title" : "this is my title",
"author" : "bob",
"tags" : "fun"
},
{
"_id" : ObjectId("4e6e4ef557b77501a49233f6"),
"title" : "this is my title",
"author" : "bob",
"tags" : "good"
},
{
"_id" : ObjectId("4e6e4ef557b77501a49233f6"),
"title" : "this is my title",
"author" : "bob",
"tags" : "fun"
}
],
"OK" : 1
}
Observe que a única coisa que muda na matriz de resultado é o que está sendo retornado no valor das tags. Se você precisar de uma referência adicional sobre como isso funciona, incluí um link aqui . Espero que isso ajude e boa sorte com sua incursão em um dos melhores sistemas NoSQL que encontrei até agora.