As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.
$slice
O operador $slice de agregação permite que você retorne um subconjunto de uma matriz percorrendo a matriz do início ou do final da matriz. Isso é usado para exibir um número limitado de itens de um campo de matriz, como os N itens superiores ou inferiores.
Parâmetros
-
array: O campo da matriz a ser fatiado. -
n: um número inteiro que especifica o número de elementos a serem retornados. Um valor positivo começa no início da matriz, enquanto um valor negativo começa no final da matriz.
Exemplo (MongoDB Shell)
O exemplo a seguir demonstra como usar $slice para devolver os dois primeiros doces favoritos de cada chef.
Crie documentos de amostra
db.sweets.insertMany([ { "_id" : 1, "name" : "Alvin", "favorites": [ "chocolate", "cake", "toffee", "beignets" ] }, { "_id" : 2, "name" : "Tom", "favorites": [ "donuts", "pudding", "pie" ] }, { "_id" : 3, "name" : "Jessica", "favorites": [ "fudge", "smores", "pudding", "cupcakes" ] }, { "_id" : 4, "name" : "Rachel", "favorites": [ "ice cream" ] } ]);
Exemplo de consulta
db.sweets.aggregate([ { $project: { _id: 0, name: 1, topTwoFavorites: { $slice: [ "$favorites", 2 ] } } } ]);
Saída
[
{ name: 'Alvin', topTwoFavorites: [ 'chocolate', 'cake' ] },
{ name: 'Tom', topTwoFavorites: [ 'donuts', 'pudding' ] },
{ name: 'Jessica', topTwoFavorites: [ 'fudge', 'smores' ] },
{ name: 'Rachel', topTwoFavorites: [ 'ice cream' ] }
]
Neste exemplo, o $slice operador é usado para extrair os dois primeiros elementos da favorites matriz para cada documento.
Exemplos de código
Para ver um exemplo de código para usar o $slice comando, escolha a guia do idioma que você deseja usar: