MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Como faço para manter documentos em agregação com $ unwind


Você não precisa de $unwind de forma alguma. Simples $match em pipeline é suficiente:
pipeline = [
    {
        "$match" : {
            "$or" : [
                {
                    "goes.fridays.fr" : 700
                },
                {
                    "goes.special" : {
                        "$elemMatch" : {
                            "date" : "2010-01-01",
                            "fr" : 1000
                        }
                    }
                }
            ]
        }
    }
]

db.students.aggregate(pipeline)

Isso pode ser feito facilmente, mesmo sem estrutura de agregação.
query = {
    "$or" : [
        {
            "goes.fridays.fr" : 700
        },
        {
            "goes.special" : {
                "$elemMatch" : {
                    "date" : "2010-01-01",
                    "fr" : 1000
                }
            }
        }
    ]
}

db.students.find(query)