$minN (operador de array)
Nesta página
Definição
Novidades na versão 5.2.
Retorna os menores valores de n
em uma array.
Sintaxe
$minN
tem a seguinte sintaxe:
{ $minN: { n: <expression>, input: <expression> } }
Comportamento
Você não pode especificar um valor de
n
menor que1
.$minN
filtra os valores denull
encontrados no arrayinput
.Se o
n
especificado for igual ao ou maior que número de elementos no arrayinput
,$minN
retornará todos os elementos no arrayinput
.Se
input
resolver para um valor que não seja da array, a operação de agregação será executada.Se o
input
contiver 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 ] }]