Definição
Dica
Sintaxe
$maxN tem a seguinte sintaxe:
{ $maxN: { n: <expression>, input: <expression> } }
Comportamento
Você não pode especificar um valor de
nmenor que1.$maxNfiltra os valores denullencontrados no arrayinput.Se o
nespecificado for igual ao ou maior que número de elementos no arrayinput,$maxNretornará todos os elementos no arrayinput.Se
inputresolver para um valor que não seja da array, a operação de agregação será executada.Se
inputcontiver elementos numéricos e string , os elementos de string serão classificados antes dos elementos numéricos, de acordo com a ordem de comparação deBSON .
Exemplo
Criar uma coleção scores com os seguintes documentos:
db.scores.insertMany([ { "playerId" : 1, "score" : [ 1, 2, 3 ] }, { "playerId" : 2, "score" : [ 12, 90, 7, 89, 8 ] }, { "playerId" : 3, "score" : [ null ] }, { "playerId" : 4, "score" : [ ] } { "playerId" : 5, "score" : [ 1293, "2", 3489, 9 ]} ])
O exemplo seguinte utiliza o operador $maxN para recuperar as duas pontuações mais altas para cada jogador. As pontuações mais altas são retornadas no novo campo maxScores criado por $addFields.
db.scores.aggregate([ { $addFields: { maxScores: { $maxN: { n: 2, input: "$score" } } } } ])
A operação retorna os seguintes resultados:
[{ "playerId": 1, "score": [ 1, 2, 3 ], "maxScores": [ 3, 2 ] }, { "playerId": 2, "score": [ 12, 90, 7, 89, 8 ], "maxScores": [ 90, 89 ] }, { "playerId": 3, "score": [ null ], "maxScores": [ ] }, { "playerId": 4, "score": [ ], "maxScores": [ ] }, { "playerId": 5, "score": [ 1293, "2", 3489, 9 ], "maxScores": [ "2", 3489 ] }]