$sliceLa
$sliceEl modificador limita el número de elementos del arreglo durante un$pushoperación. Para proyectar o devolver un número especificado de elementos de arreglo de una operación de lectura, consulta el operador de proyección$sliceen su lugar.Para utilizar el modificador
$slice, debe aparecer con el modificador$each. Puedes pasar un arreglo vacío[]al modificador$eachde modo que sólo el modificador$slicetenga efecto.{ $push: { <field>: { $each: [ <value1>, <value2>, ... ], $slice: <num> } } } El
<num>puede ser:ValorDescripciónZero
Actualizar el arreglo
<field>a un arreglo vacío.Negativo
Para actualizar el arreglo
<field>para que contenga solo los últimos<num>elementos.Positivo
Para actualizar el arreglo
<field>contiene solo los primeros<num>elementos.
Comportamiento
A partir de MongoDB 5.0, los operadores de actualización procesan los campos de documentos con nombres basados en cadenas en orden lexicográfico. Los campos con nombres numéricos se procesan en orden numérico. Consulta Comportamiento del operador de actualización para obtener más información.
El orden en que aparecen los modificadores es irrelevante. Las versiones anteriores requerían que el modificador apareciera como el $each primero si se usaba junto con.$slice Para ver la lista $push de modificadores disponibles para, consulte Modificadores.
Intentar utilizar el modificador $slice sin el modificador $each resulta en un error.
Ejemplos
Rebanar desde el final de la matriz
Una colección students contiene el siguiente documento:
db.students.insertOne([ { _id : 1, "scores" : [ 40, 50, 60 ] } ] )
La siguiente operación añade nuevos elementos al arreglo scores y luego utiliza el modificador $slice para acortar el arreglo a los últimos cinco elementos:
db.students.updateOne( { _id: 1 }, { $push: { scores: { $each: [ 80, 78, 86 ], $slice: -5 } } } )
El resultado de la operación es cortar los elementos de la matriz scores actualizada en los últimos cinco elementos:
{ "_id" : 1, "scores" : [ 50, 60, 80, 78, 86 ] }
Corte desde el frente de la matriz
Una colección students contiene el siguiente documento:
db.students.insertOne( [ { _id : 2, "scores" : [ 89, 90 ] } ] )
La siguiente operación agrega nuevos elementos a la scores matriz y luego utiliza el modificador para recortar la matriz a los primeros tres $slice elementos.
db.students.updateOne( { _id: 2 }, { $push: { scores: { $each: [ 100, 20 ], $slice: 3 } } } )
El resultado de la operación es dividir los elementos de la matriz scores actualizada en los primeros tres elementos:
{ "_id" : 2, "scores" : [ 89, 90, 100 ] }
Actualizar el arreglo usando sólo slice
Una colección students contiene el siguiente documento:
db.students.insertOne( [ { _id : 3, "scores" : [ 89, 70, 100, 20 ] } ] )
Para actualizar el campo scores solo con los efectos del modificador $slice, especifica el número de elementos a recortar (por ejemplo, -3) para el $slice modificador y un arreglo vacío [] para el $each modificador, como en el siguiente ejemplo:
db.students.updateOne( { _id: 3 }, { $push: { scores: { $each: [ ], $slice: -3 } } } )
El resultado de la operación consiste en seleccionar los elementos del arreglo scores hasta los tres últimos elementos:
{ "_id" : 3, "scores" : [ 70, 100, 20 ] }
Utilice $slice con otros $push modificadores
Añada el siguiente documento a la colección students:
db.students.insertOne( { "_id" : 5, "quizzes" : [ { "wk": 1, "score" : 10 }, { "wk": 2, "score" : 8 }, { "wk": 3, "score" : 5 }, { "wk": 4, "score" : 6 } ] } )
La siguiente $push operación utiliza:
el modificador
$eachpara agregar múltiples documentos al arregloquizzes,el modificador
$sortpara ordenar todos los elementos del arregloquizzesmodificado por el camposcoreen orden descendente, yel modificador para
$slicemantener solo los primeros tres elementos ordenados de laquizzesmatriz.
db.students.updateOne( { _id: 5 }, { $push: { quizzes: { $each: [ { wk: 5, score: 8 }, { wk: 6, score: 7 }, { wk: 7, score: 6 } ], $sort: { score: -1 }, $slice: 3 } } } )
Después de la operación, solo los tres cuestionarios con mayor puntuación están en el arreglo:
{ "_id" : 5, "quizzes" : [ { "wk" : 1, "score" : 10 }, { "wk" : 2, "score" : 8 }, { "wk" : 5, "score" : 8 } ] }
El orden de los modificadores no es material para el orden en que se procesan los modificadores. Consulta Modificadores para más detalles.