I have array in subdocument like this
{
"_id" : ObjectId("512e28984815cbfcb21646a7"),
"descDay" : [
{
"language" : "en",
"desc": "day description"
},
{
"language" : "es",
"desc": "descripcion del dia"
}
]
}
I want to filter the subdocuments by language. I can do that like this
db.test.aggregate([
{ $project: {
descDay: {$filter: {
input: '$list',
as: 'item',
cond: {$gt: ['$$item.language', 'en']}
}}
}}
])
that would give me something like
{
"_id" : ObjectId("512e28984815cbfcb21646a7"),
"descDay" : [
{
"language" : "en",
"desc": "day description"
}]
}
but I need descDay to be a document not an array, something like this:
{
"_id" : ObjectId("512e28984815cbfcb21646a7"),
"descDay" :
{
"language" : "en",
"desc": "day description"
}
}
how can I get that?