'aggregate mongodb search in array
my documents in mongodb collection :
{
'id' : 'ID1',
'status' : 'ST1',
'logs' : [
{
'id' : 'ID2',
'status_old' : 'ST2',
'status_new' : 'ST3',
},
{
'id' : 'ID3',
'status_old' : 'ST3',
'status_new' : 'ST4',
}
]
},
{
'id' : 'ID4',
'status' : 'ST4',
'logs' : [
{
'id' : 'ID5',
'status_old' : 'ST2',
'status_new' : 'ST3',
}
]
}
I want to pass the documents through the following two filters
filter1 :
where
( status = 'ST1' OR
status_old = 'ST1' OR
status_new = 'ST1' )
Then the answer obtained should be placed in the following filter (condition):
filter2 :
where
( status = 'ST2' OR
status_old = 'ST2' OR
status_new = 'ST2' )
The answer is stated with two conditions and according to the documents provided above, the following is the case:
{
'id' : 'ID1',
'status' : 'ST1',
'logs' : [
{
'id' : 'ID2',
'status_old' : 'ST2',
'status_new' : 'ST3',
},
{
'id' : 'ID3',
'status_old' : 'ST3',
'status_new' : 'ST4',
}
]
},
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
Solution | Source |
---|