EXPLAIN SYNTAX SELECT * FROM system.numbers AS a, system.numbers AS b, system.numbers AS c;
```
```sql
SELECT
`--a.number` AS `a.number`,
`--b.number` AS `b.number`,
number AS `c.number`
FROM
(
SELECT
number AS `--a.number`,
b.number AS `--b.number`
FROM system.numbers AS a
CROSS JOIN system.numbers AS b
) AS `--.s`
CROSS JOIN system.numbers AS c
```
### EXPLAIN PLAN {#explain-plan}
Дамп шагов выполнения запроса.
Настройки:
-`header` — выводит выходной заголовок для шага. По умолчанию: 0.
-`description` — выводит описание шага. По умолчанию: 1.
-`actions` — выводит подробную информацию о действиях, выполняемых на данном шаге. По умолчанию: 0.
Пример:
```sql
EXPLAIN SELECT sum(number) FROM numbers(10) GROUP BY number % 4;
```
```sql
Union
Expression (Projection)
Expression (Before ORDER BY and SELECT)
Aggregating
Expression (Before GROUP BY)
SettingQuotaAndLimits (Set limits and quota after reading from storage)
ReadFromStorage (SystemNumbers)
```
!!! note "Примечание"
Оценка затрат на шаг и запрос не поддерживается.
### EXPLAIN PIPELINE {#explain-pipeline}
Настройки:
-`header` — выводит заголовок для каждого выходного порта. По умолчанию: 0.
-`graph` — использование DOT (язык описания графа). По умолчанию: 0.
-`compact` — выводит граф в компактном режиме, если граф включен. По умолчанию: 1.
-`indexes` — показывает используемые индексы, количество отфильтрованных кусков и гранул для каждого примененного индекса. По умолчанию: 0. Поддерживается для таблиц семейства [MergeTree](../../engines/table-engines/mergetree-family/mergetree.md).
Пример:
```sql
EXPLAIN PIPELINE SELECT sum(number) FROM numbers_mt(100000) GROUP BY number % 4;