Definición
$bottomNuevo 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).
Sintaxis
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 |
Comportamiento
Comportamiento de ordenamiento
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 | ||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
| | ||||||||||
|
| | ||||||||||
|
| |
Input Values
El campo input debe resolver en un arreglo. En caso de que especifiques un input que no sea un arreglo, MongoDB arrojará un error.
Ejemplo
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.