Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
$bucket
Novità dalla versione 8.0
Non supportato dal cluster Elastic.
La fase di $bucket aggregazione in Amazon DocumentDB consente di raggruppare i documenti di input in bucket in base a un'espressione e ai limiti del bucket specificati. Ciò può essere utile per analizzare dati che rientrano in determinati intervalli di valori o categorie.
Parametri
-
groupBy(obbligatorio): L'espressione che specifica il valore in base al quale raggruppare. -
boundaries(obbligatorio): Una matrice di valori doppi che definiscono i limiti del bucket. I documenti vengono assegnati ai bucket in base al valore dell'groupByespressione che rientra nei limiti specificati. -
default(opzionale): Un valore letterale che viene emesso per i documenti il cui valore digroupByespressione non rientra in nessuno dei limiti specificati. -
output(opzionale): Un oggetto che specifica le informazioni da restituire per ogni bucket. È possibile utilizzare operatori di accumulazione come$sum,$avg$min, e$maxper calcolare aggregazioni per ogni bucket.
Esempio (MongoDB Shell)
L'esempio seguente mostra come utilizzare lo $bucket stage per raggruppare i dati di vendita per fascia di prezzo.
Crea documenti di esempio
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") } ]);
Esempio di query
db.sales.aggregate([ { $bucket: { groupBy: "$price", boundaries: [0, 10, 20, 30], default: "Other", output: { "count": { $sum: 1 }, "totalQuantity": { $sum: "$quantity" } } } }, { $sort: { _id: 1 } } ])
Output
[
{ _id: 0, count: 1, totalQuantity: 3 },
{ _id: 10, count: 2, totalQuantity: 4 },
{ _id: 20, count: 2, totalQuantity: 2 }
]
Esempi di codice
Per visualizzare un esempio di codice per l'utilizzo del $bucket comando, scegliete la scheda relativa alla lingua che desiderate utilizzare: