Docs Menu
Docs Home
/ /

Ejecute pipelines de agregación en sus datos

Las canalizaciones de agregación transforman sus documentos en un conjunto de resultados agregados. En Atlas Charts, las canalizaciones de agregación se utilizan comúnmente para visualizar nuevos campos creados a partir de resultados calculados de campos preexistentes, pero también tienen muchas otras aplicaciones.

Para crear una canalización de agregación:

  1. En el Query Barra, introduzca una canalización de agregación. La canalización debe estar entre corchetes.

  2. (Opcional) Seleccione Format para organizar la consulta de la siguiente manera:

    • Dividir la consulta en varias líneas

    • Sangrar la consulta según las convenciones JSON

  3. (Condicional) Si seleccionó la opción Format, haga clic en Close cuando termine.

  4. Haga clic en Apply para ejecutar su canalización.

El siguiente gráfico muestra el total de ventas de una empresa de suministros de oficina, clasificado por ubicación de tienda. El gráfico utiliza la siguiente secuencia de agregación en la barra Query:

[
{
$unwind: "$items"
},
{
$addFields: {
saleAmount: {
$multiply: [ "$items.price", "$items.quantity" ]
}
}
}
]

Esta canalización de agregación procesa los datos de recopilación utilizando el siguiente orden:

  1. El La etapa $unwinddesenrolla la matriz items y genera un nuevo documento para cada artículo de la matriz. Cada elemento de la matriz items contiene un artículo vendido durante una transacción.

  2. La etapa añade un nuevo campo a los $addFields documentos saleAmount llamado. La expresión establece el $multiply valor saleAmount de items.price como el producto de items.quantity y. Puede ver este nuevo campo resaltado en la siguiente captura de pantalla:

Ejemplo de pipeline de agregación
haga clic para ampliar

Una vez procesados ​​los datos mediante el pipeline, el gráfico muestra Sum de todos los saleAmounts categorizados por ubicación de la tienda.

Si su agregación no es válida, Charts muestra el ícono en la Query barra.

Haga clic en la barra Query si aún no se muestra para ver los detalles del error. Los gráficos muestran los detalles de los errores:

  • Errores del lado del cliente, como JSON mal formados, y

  • Errores del lado del servidor, como por ejemplo, MQL o etapas de canalización no compatibles.

Error de ejemplo en el pipeline de agregación
haga clic para ampliar

Revise los detalles del error y luego ajuste su canal de agregación según corresponda.

  • Los gráficos no admiten el operador en consultas de agregación. Sin embargo, puede usarlo en las canalizaciones de fuentes de datos. Para obtener más información sobre cómo usar las canalizaciones para preprocesar datos antes de que lleguen al Generador de gráficos,$lookup consulte Crear y administrar vistas de gráficos.

  • Charts admite el operador solo cuando se define el cuerpo de la función en una sola línea y se encierra entre comillas dobles. Para usar este operador en las consultas de agregación, se debe usar la siguiente $function sintaxis:

    {
    $function: {
    body: "function(arg1, arg2, ...) { ... }",
    args: <array expression>,
    lang: "js"
    }
    }

Volver

Agregar un campo de búsqueda

En esta página