Menu Docs
Página inicial do Docs
/
Manual do MongoDB
/ / /

$minN (operador de array)

Nesta página

  • Definição
  • Sintaxe
  • Comportamento
  • Exemplo
$minN

Novidades na versão 5.2.

Retorna os menores valores de n em uma array.

Dica

Veja também:

$maxN

$minN tem a seguinte sintaxe:

{ $minN: { n: <expression>, input: <expression> } }
Campo
Descrição
n
Uma expressão que é resolvida para um número inteiro positivo. O inteiro especifica o número de elementos da array que $minN retorna.
input
Uma expressão que se resolve na array da qual retornar os elementos n mínimos.
  • Você não pode especificar um valor de n menor que 1.

  • $minN filtra os valores de null encontrados no array input.

  • Se o n especificado for igual ao ou maior que número de elementos no array input , $minN retornará todos os elementos no array input.

  • 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.

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 ]
}]

Voltar

$minN

Próximo

$millisecond