Чем EXPLAIN отличается от EXPLAIN ANALYZE в Postgres-подобной СУБД?
A
EXPLAIN выполняет запрос и показывает фактическое время, а EXPLAIN ANALYZE — только план без выполнения.B
EXPLAIN показывает план без выполнения запроса, а EXPLAIN ANALYZE выполняет запрос и добавляет фактические времена/строки.CОба варианта всегда только строят план и ничего не исполняют.
DОба варианта всегда исполняют запрос, разницы нет.
Правильный ответ.
EXPLAIN — план, EXPLAIN ANALYZE — план плюс фактические измерения.Разбор
Обычный EXPLAIN полезен, когда вы хотите оценить риск и структуру плана, не запуская потенциально тяжёлый запрос. EXPLAIN ANALYZE действительно выполняет запрос и показывает фактические времена и количество строк на шагах. Это помогает обнаружить расхождения между оценками и реальностью, но может быть дорого на больших таблицах.
Проверь себя · 1/3разбор после ответа
Есть индекс по
orders.created_at, но EXPLAIN для фильтра WHERE date(created_at) = current_date показывает Seq Scan. Почему это часто происходит?Ещё вопросы по теме «EXPLAIN и оптимизация»
- Вы хотите добавить новый запрос в дашборд и боитесь, что он сильно нагрузит базу, потому что таблица `events` очень большая. Что дает запуск `EXPLAIN` для этого запроса?
- В выводе `EXPLAIN` вы видите узел `Seq Scan on orders`. Что это обычно означает?
- В плане `EXPLAIN` для запроса по пользователю вы видите `Index Scan using orders_user_id_idx on orders`. Какой вывод наиболее корректен?
- На большой таблице `events` запрос `SELECT * FROM events ORDER BY created_at DESC LIMIT 100` неожиданно работает быстро. Какое объяснение наиболее вероятно при наличии индекса по `created_at`?
- Есть индекс по `orders.created_at`, но `EXPLAIN` для фильтра `WHERE date(created_at) = current_date` показывает `Seq Scan`. Почему это часто происходит?
- Все вопросы по «EXPLAIN и оптимизация» →