Definição
Novidades na versão 5.2.
Retorna os menores valores de n em uma array.
Dica
Sintaxe
$minN tem a seguinte sintaxe:
{ $minN: { n: <expression>, input: <expression> } }
Comportamento
Você não pode especificar um valor de
nmenor que1.$minNfiltra os valores denullencontrados no arrayinput.Se o
nespecificado for igual ao ou maior que número de elementos no arrayinput,$minNretornará 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 o
inputcontiver elementos numéricos e de string, os elementos numéricos serão classificados antes dos elementos de string de acordo com a ordem de comparação BSON.
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 $minN para recuperar as duas pontuações mais baixas para cada jogador. As pontuações mais baixas são retornadas no novo campo minScores criado por $addFields.
db.scores.aggregate([ { $addFields: { minScores: { $minN: { n: 2, input: "$score" } } } } ])
A operação retorna os seguintes resultados:
[{ "playerId": 1, "score": [ 1, 2, 3 ], "minScores": [ 1, 2 ] }, { "playerId": 2, "score": [ 12, 90, 7, 89, 8 ], "minScores": [ 7, 8 ] }, { "playerId": 3, "score": [ null ], "minScores": [ ] }, { "playerId": 4, "score": [ ], "minScores": [ ] }, { "playerId": 5, "score": [ 1293, "2", 3489, 9 ], "minScores": [ 9, 1293 ] }]