Możesz dodać $cond
operator do uwzględnienia przerw, po którym następuje $filter
aby filtrować puste wartości tablicy.
Potrzebujesz dwóch zmian.
Pierwsza zmiana polegająca na przechowywaniu wartości [] dla przerw zamiast tablicy z wartościami null.
Zaktualizuj wewnętrzne wyrażenie $let na poniższe:
{
"$let":{
"vars":{"five":...},
"in":{
"$cond":[
{"$eq":["$$five",[]]},
"$$five",
[{"$arrayElemAt":[{"$arrayElemAt":["$$five",-1]},0]},
....
{"$arrayElemAt":[{"$arrayElemAt":["$$five",-1]},-1]}]
]
}
}
}
Druga zmiana polegająca na filtrowaniu pustych wartości tablicy z danych wyjściowych.
{
"$project":{
"data":{
"$let":{
"vars":{"mints":...},
"in":{"$filter":{"input":{"$map":...},as:"flr", "cond":{"$ne":["$$flr",[]]}}}
}
}
}
}