Запрос SELECT user_id, COUNT(*) FROM orders WHERE amount > 100 GROUP BY user_id HAVING COUNT(*) > 5 работает. Если вынести HAVING в WHERE, что произойдёт?
SQLmediummiddle
Варианты ответа
Ошибка: нельзя использовать COUNT(*) в WHERE, потому что WHERE отрабатывает ДО агрегатов и группировки строк
Всё будет работать корректно, WHERE и HAVING — синонимы, отличаются только синтаксической позицией в запросе
Будет тот же результат, но быстрее — оптимизатор перенесёт условие из HAVING в WHERE для раннего фильтра
Будет работать, но вернёт меньше строк, потому что WHERE применяется к агрегату после внутренней группировки
Разбор ответа
Подробный разбор с объяснением «почему правильный ответ верный» и почему остальные неверны — после регистрации.
2475 вопросов с разбором, quiz-режим с проверкой, AI-собес и подготовка к интервью аналитика.