Make the MongoDB docs better! We value your opinion. Share your feedback for a chance to win $100.
Click here >
Docs Menu
Docs Home
/ /
Expresiones

$bottom (operador de expresión)

$bottom

Nuevo en la versión 8.3.

Devuelve el último elemento dentro de un arreglo según el orden de clasificación especificado.

Nota

Desambiguación

Esta página describe el operador de expresión $bottom. Para el $bottom operador de acumulación, consulte $bottom (operador de acumulación).

Cuando se utiliza como operador de expresión, $bottom tiene la siguiente sintaxis:

{
$bottom:
{
sortBy: <expression>,
input: <expression>
}
}
Campo
Necesidad
Descripción

sortBy

Requerido

Especifica el orden de los resultados. Consultar Comportamiento de clasificación para obtener más información.

entrada

Requerido

El arreglo que $bottom evalúa.

MongoDB ordena el arreglo input en función del valor sortBy. La siguiente tabla proporciona ejemplos de diferentes opciones de clasificación:

input
sortBy
Ordenado input
[ 8, 3, 1, 10]

1

[1, 3, 8, 10]
[ 8, 3, 1, 10]

-1

[10, 8, 3, 1]
[
{ a: 1, b: 1 },
{ a: 2, b: 2 },
{ a: 2, b: 1 }
]

{ a: 1, b: 1 }

[
{ a: 1, b: 1 },
{ a: 2, b: 1 },
{ a: 2, b: 2 }
]

El campo input debe resolver en un arreglo. En caso de que especifiques un input que no sea un arreglo, MongoDB arrojará un error.

El siguiente ejemplo utiliza la colección movies de la muestra datasets sample_mflix. Para más información sobre cómo cargar este datasets en tu implementación, consulta Carga el datasets de muestra.

La colección movies contiene documentos que se asemejan al siguiente ejemplo:

{
_id: ObjectId('573a1396f29313caabce4a9a'),
year: 1972,
genres: [ 'Crime', 'Drama' ],
title: 'The Godfather',
cast: [ 'Marlon Brando', 'Al Pacino', 'James Caan', 'Richard S. Castellano' ],
directors: [ 'Francis Ford Coppola' ],
runtime: 175,
...
}

La siguiente pipeline de agregación utiliza $bottom en el arreglo cast:

db.movies.aggregate([
{
$match: { title: "The Godfather" }
},
{
$project: {
_id: 0,
title: 1,
lastCastMemberAlphabetically: {
$bottom: {
sortBy: 1,
input: "$cast"
}
}
}
}
])
[
{
title: 'The Godfather',
lastCastMemberAlphabetically: 'Richard S. Castellano'
}
]

En este ejemplo, $bottom ordena el arreglo existente cast en orden alfabético ascendente y devuelve el último valor.

En esta página