I have a query to find if a user CreatedBy
is in a SharedWith
. I want to inverse the query to check if the CreatedBy
is not in SharedWith
.
[
{
"$match": {
"$and": [
{
"$and": [
{
"SharedWith": {
"$exists": true
}
},
{
"$expr": {
"$in": [
"$CreatedBy",
"$Multi_User"
]
}
}
]
}
]
}
}
]
MongoDB does not support a direct $nin
or $not
for $and
query.
Any idea how to achieve this.
The user document looks like this,
Collection = [
{"CreatedBy":
{"_id": "User001",
"Email": "[email protected]",
"Name": "User001"},
"SharedWith": [
{"_id": "User001",
"Email": "[email protected]",
"Name": "User001"},
{"_id": "User002",
"Email": "[email protected]",
"Name": "User002"},
{"_id": "User003",
"Email": "[email protected]",
"Name": "User003"},
]}
]
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…