MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Comment puis-je conserver des documents en agrégation avec $unwind

Vous n'avez pas besoin de $unwind du tout. $match simple dans le pipeline est suffisant :

pipeline = [
    {
        "$match" : {
            "$or" : [
                {
                    "goes.fridays.fr" : 700
                },
                {
                    "goes.special" : {
                        "$elemMatch" : {
                            "date" : "2010-01-01",
                            "fr" : 1000
                        }
                    }
                }
            ]
        }
    }
]

db.students.aggregate(pipeline)

Cela peut être fait facilement même sans cadre d'agrégation.

query = {
    "$or" : [
        {
            "goes.fridays.fr" : 700
        },
        {
            "goes.special" : {
                "$elemMatch" : {
                    "date" : "2010-01-01",
                    "fr" : 1000
                }
            }
        }
    ]
}

db.students.find(query)