I have users' collection whose schema is like:
{
_id: unique number,
name: 'asdf',
age: '12',
gender: 'm',
address: [
{area: 'sdf',
city: 'sdq',
state: 'wfw'},
{area: 'asdf',
city: 'sdfs',
state: 'vfdwd'}
]
}
I want to find out the users for whom all the values of state
in address
should be the value I pass. If even one of the state
value doesn't match with the value I pass the user shouldn't be returned.
I tried simple find, aggregation framework with $unwind
, $match
but nothing seemed to get solution. Can you please help me out...
Thanks
P.S. please bear with multiple addresses for the sake of question. :)
I don't know if I understand.
I replicated your document. When you want to retrieve an user by
state
you can do in many waysIf you search with single value you can do
and retrieve an user
You can use
$all
or you can use
$and
But I don't know if I understand your question
Update and the correct answer
Let me Know