Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
La fase $out de una canalización de agregación permite escribir los documentos resultantes de la canalización en una colección especificada. Normalmente se usa para guardar la salida de operaciones de agregación complejas para su uso o análisis posteriores. Cuando se usa, la colección especificada se crea o reemplaza por los nuevos documentos.
Syntax
{
$out: "<outputCollection>"
}
Parámetros
| Parámetro | Description |
|---|---|
<outputCollection> |
Nombre de la colección donde se almacenará el resultado de la agregación. |
Examples
Considere este documento de ejemplo de la colección de tiendas.
{
"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4",
"name": "First Up Consultants | Beverage Shop - Satterfieldmouth",
"location": {
"lat": -89.2384,
"lon": -46.4012
},
"staff": {
"totalStaff": {
"fullTime": 8,
"partTime": 20
}
},
"sales": {
"totalSales": 75670,
"salesByCategory": [
{
"categoryName": "Wine Accessories",
"totalSales": 34440
},
{
"categoryName": "Bitters",
"totalSales": 39496
},
{
"categoryName": "Rum",
"totalSales": 1734
}
]
},
"promotionEvents": [
{
"eventName": "Unbeatable Bargain Bash",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 6,
"Day": 23
},
"endDate": {
"Year": 2024,
"Month": 7,
"Day": 2
}
},
"discounts": [
{
"categoryName": "Whiskey",
"discountPercentage": 7
},
{
"categoryName": "Bitters",
"discountPercentage": 15
},
{
"categoryName": "Brandy",
"discountPercentage": 8
},
{
"categoryName": "Sports Drinks",
"discountPercentage": 22
},
{
"categoryName": "Vodka",
"discountPercentage": 19
}
]
},
{
"eventName": "Steal of a Deal Days",
"promotionalDates": {
"startDate": {
"Year": 2024,
"Month": 9,
"Day": 21
},
"endDate": {
"Year": 2024,
"Month": 9,
"Day": 29
}
},
"discounts": [
{
"categoryName": "Organic Wine",
"discountPercentage": 19
},
{
"categoryName": "White Wine",
"discountPercentage": 20
},
{
"categoryName": "Sparkling Wine",
"discountPercentage": 19
},
{
"categoryName": "Whiskey",
"discountPercentage": 17
},
{
"categoryName": "Vodka",
"discountPercentage": 23
}
]
}
]
}
Ejemplo 1:Escritura de resultados de agregación en una nueva colección
Esta consulta escribe almacenes con ventas totales superiores a 30 000 en una nueva colección denominada highSales.
db.stores.aggregate([
{
$match: {
"sales.salesByCategory.totalSales": { $gt: 30000 }
}
},
{
$out: "highSales"
}
])
Ejemplo 2: Escritura de datos procesados en otra colección
Esta consulta extrae eventos de promoción y los escribe en una colección denominada promotionEventsSummary.
db.stores.aggregate([
{
$project: {
eventName: 1,
promotionalDates: 1,
"discounts.categoryName": 1,
"discounts.discountPercentage": 1
}
},
{
$out: "promotionEventsSummary"
}
])