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á.
$bucket
Novo a partir da versão 8.0
Não é compatível com o cluster elástico.
O estágio $bucket de agregação no Amazon DocumentDB permite agrupar documentos de entrada em buckets com base em uma expressão e limites de bucket especificados. Isso pode ser útil para analisar dados que se enquadram em determinadas faixas de valores ou categorias.
Parâmetros
-
groupBy(obrigatório): a expressão que especifica o valor pelo qual agrupar. -
boundaries(obrigatório): uma matriz de valores duplos que define os limites do intervalo. Os documentos são atribuídos a compartimentos com base no valor dagroupByexpressão que está dentro dos limites especificados. -
default(opcional): um valor literal que é gerado para documentos cujo valor degroupByexpressão não se enquadra em nenhum dos limites especificados. -
output(opcional): um objeto que especifica as informações a serem enviadas para cada bucket. Você pode usar operadores de acumulador como$sum,$avg$min, e$maxpara calcular agregações para cada bucket.
Exemplo (MongoDB Shell)
O exemplo a seguir demonstra como usar o $bucket estágio para agrupar dados de vendas por faixa de preço.
Crie documentos de amostra
db.sales.insertMany([ { item: "abc", price: 10, quantity: 2, date: new Date("2020-09-01") }, { item: "def", price: 20, quantity: 1, date: new Date("2020-10-01") }, { item: "ghi", price: 5, quantity: 3, date: new Date("2020-11-01") }, { item: "jkl", price: 15, quantity: 2, date: new Date("2020-12-01") }, { item: "mno", price: 25, quantity: 1, date: new Date("2021-01-01") } ]);
Exemplo de consulta
db.sales.aggregate([ { $bucket: { groupBy: "$price", boundaries: [0, 10, 20, 30], default: "Other", output: { "count": { $sum: 1 }, "totalQuantity": { $sum: "$quantity" } } } }, { $sort: { _id: 1 } } ])
Saída
[
{ _id: 0, count: 1, totalQuantity: 3 },
{ _id: 10, count: 2, totalQuantity: 4 },
{ _id: 20, count: 2, totalQuantity: 2 }
]
Exemplos de código
Para ver um exemplo de código para usar o $bucket comando, escolha a guia do idioma que você deseja usar: