Что вернёт запрос SELECT region, category, COUNT(*) FROM sales GROUP BY ROLLUP(region, category)?
AСтроки по каждой паре, подытоги по каждому региону с
NULL в category и общий итог с NULL в обоих столбцахBТолько строки по каждой уникальной паре
region и category — итоги не добавляютсяCСтроки по каждой категории с
NULL в region и общий итог без разбивки по регионамDДекартово произведение всех регионов и категорий со значениями для каждой ячейки
Правильный ответ.
ROLLUP(a, b) генерирует три уровня группировки: (a, b), (a) и (). Строки с итогами помечаются NULL в соответствующих столбцах.Разбор
GROUP BY ROLLUP(a, b) генерирует группировки: (a, b), (a), (). Для таблицы продаж: подсчёт по каждой паре регион-категория, подытог по каждому региону с NULL вместо category, и общий итог с NULL в обоих столбцах. Функция GROUPING(col) позволяет отличить синтетический NULL от реального NULL в данных.
Проверь себя · 1/3разбор после ответа
В таблице
users есть колонка middle_name, в которой часто хранится NULL. Что вернёт выражение COUNT(middle_name)?Ещё вопросы по теме «Агрегация, GROUP BY и HAVING»
- Что делает оператор `DISTINCT`?
- Что делает `HAVING`?
- Есть таблица `orders(user_id, amount)`. Какой запрос посчитает сумму всех заказов по каждому пользователю?
- Нужно посчитать сумму оплаченных заказов по каждому пользователю. В таблице `orders` есть поля `user_id`, `amount`, `status`. Какой запрос корректен и наиболее эффективен?
- В таблице `users` есть колонка `middle_name`, в которой часто хранится `NULL`. Что вернёт выражение `COUNT(middle_name)`?
- Все вопросы по «Агрегация, GROUP BY и HAVING» →