I want to bitwise check in my data, but not return data.Rights default param is 1. How do I solve this problem?
db.getCollection('forms').find(
{
"IsActive" : true,
"$or" :
[
{ "$where" : "(this.Acls.Rights & 1) == 1" , "Acls.Actor._id" : ObjectId("5565f392a6df191eb4689bec") },
{ "$where" : "(this.Acls.Rights & 1) == 1" , "Acls.Actor._id" : ObjectId("5565f392a6df191eb4689bed") }
]
}
)
Here is a document I expect to match:
{
"_id" : ObjectId("55686c44a6df1a1008c0b148"),
"IsActive" : true,
"Acls" : [
{
"_id" : ObjectId("557820b1a6df1a032c2c643a"),
"IsActive" : true,
"Actor" : {
"_id" : ObjectId("5565f392a6df191eb4689bec"),
"IsActive" : true,
"Name" : "admin",
"TypeId" : 2
},
"Department" : null,
"Rights" : NumberLong(1)
}
],
"AclCount" : 1
}
The problem with your logic here is that the JavaScript evaluation of the
$where
clause does not have the same "abilities" as the MongoDB "native" search with regards to "dot notation".As such, you need to use JavaScript methods of evaluating "each" array element for the properties you want to use. In order to do this, the best condition to use here is the JavaScript
.some()
array buit-in. It returnstrue/false
to the condition if "any" of the array elements meets your condition and most importantly the "first" that is found without traversing all array elements.Which also means ( and I hate to be the bearer of bad news here ) that your logic for the comparison of
ObjectId
in a "matching pair" does not work here without doing the same.In a normal case you would use
$elemMatch
to ensure that both properties where met for a specific array element, but you cannot use a$where
clause inside$elemMatch
, so all the logic needs to be in JavaScript:Given the performance problems of
$where
( cannot use an index for it's conditions ) I would strongly suggest you find alternate means of "matching your ACL" here to the "bitwise" method you are using.Yes, other options might come at a greater storage cost, but the trade-off here is that you will get faster query results with elements you can directly match with an
$elemMatch
clause.