Analiza la ejecución de consultas con Query Explain
En esta página, se describe cómo recuperar información sobre la ejecución de consultas cuando ejecutas una consulta.
Usa la función Query Explain
Puedes usar Query Explain para comprender cómo se ejecutan tus consultas. Esto proporciona detalles que puedes usar para optimizar tus consultas.
Puedes usar Query Explain a través de la consola de Google Cloud .
Console
Ejecuta una consulta en el Editor de consultas y abre la pestaña Explicación:
-
En la consola de Google Cloud , ve a la página Bases de datos.
- En la lista de bases de datos, selecciona una de Firestore. La consola de Google Cloud abre el Explorador de Firestore para esa base de datos.
- Ingresa una consulta en el editor de consultas y haz clic en Ejecutar.
-
Haz clic en la pestaña Explicación para ver el resultado del análisis de la consulta.
Análisis
El resultado de Query Explain contiene dos componentes principales: las estadísticas de resumen y el árbol de ejecución. Considera esta consulta como ejemplo:
db.pipeline().collection('/users').sort(field("status").ascending()).limit(100)
Estadísticas de resumen
La parte superior del resultado explicado contiene un resumen de las estadísticas de ejecución. Usa estas estadísticas para determinar si una búsqueda tiene una latencia o un costo altos. También contiene estadísticas de memoria que te permiten saber qué tan cerca está tu consulta de los límites de memoria.
Execution:
results returned: 2
request peak memory usage: 20.25 KiB (20,736 B)
data bytes read: 148 B
entity row scanned: 2
Billing:
read units: 1
Árbol de ejecución
El árbol de ejecución describe la ejecución de la consulta como una serie de nodos. Los nodos inferiores (nodos hoja) recuperan datos de la capa de almacenamiento, que recorre el árbol hacia arriba para generar una respuesta a la consulta.
Para obtener detalles sobre cada nodo de ejecución, consulta la referencia de ejecución.
Si deseas obtener detalles para usar esta información y optimizar tus consultas, revisa Optimiza la ejecución de consultas.
A continuación, se muestra un ejemplo de un árbol de ejecución:
Tree:
• Compute
| $out_1: map_set($record_1, "__name__", $__name___1, "__key__", unset)
| is query result: true
|
| Execution:
| records returned: 2
| latency: 5.96 ms (local <1 ms)
|
└── • Compute
| $__name___1: map_get($record_1, "__key__")
|
| Execution:
| records returned: 2
| latency: 5.88 ms (local <1 ms)
|
└── • MajorSort
| fields: [$v_1 ASC]
| output: [$record_1]
| limit: 100
|
| Execution:
| records returned: 2
| latency: 5.86 ms (local <1 ms)
| peak memory usage: 20.25 KiB (20,736 B)
|
└── • Compute
| $v_1: map_get($record_1, "status")
|
| Execution:
| records returned: 2
| latency: 5.23 ms (local <1 ms)
|
└── • TableScan
source: /users
order: UNDEFINED
properties: *
row range: (-∞..+∞)
output record: $record_1
variables: [$record_1]
Execution:
records returned: 2
latency: 4.68 ms
records scanned: 2
data bytes read: 148 B
¿Qué sigue?
- Para obtener información sobre los nodos del árbol de ejecución, consulta la referencia de ejecución de consultas.
- Para obtener información sobre cómo optimizar tus consultas, revisa Optimiza la ejecución de consultas.