MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

MongoDB – $setIsSubset-Operator funktioniert nicht mit $match-Phase

Sie sollten $expr verwenden wenn Sie $setIsSubset verwenden möchten (was ein Ausdruck ist) innerhalb von $match :

db.test.aggregate([
    {
        $match: {
            $expr: {
                $setIsSubset: [["hello", "you"], "$words"]}
            }
        }
])

Für MongoDB-Versionen kleiner als 3.6 Sie können $redact verwenden :

db.test.aggregate([
    {
        $redact: {
            $cond: {
                if: { $eq: [ { $setIsSubset: [["hello", "you"], "$words"]}, true ] },
                then: "$$KEEP",
                else: "$$PRUNE"
            }
        }
    }
])