В таблице пользователей 1000 строк, у 200 из них поле email равно NULL. Чем будут отличаться результаты SELECT COUNT(*) FROM users и SELECT COUNT(email) FROM users?
AОба запроса вернут
1000: функция COUNT подсчитывает все строки таблицы независимо от значений в столбцахBОба запроса вернут
800: строки со значением NULL пропускаются обеими функциями подсчёта по одинаковому правилуCПервый вернёт
800 без NULL, второй вернёт 1000 как полное число строк таблицы пользователей в выдачеDПервый вернёт
1000 (число строк), второй вернёт 800: COUNT(email) пропускает строки со значением NULLПравильный ответ.
COUNT(*) считает все строки, а COUNT(столбец) считает только строки, где значение столбца не равно NULL.Разбор
COUNT(*) подсчитывает количество строк в результате независимо от значений в столбцах — для 1000 строк вернёт 1000. COUNT(email) подсчитывает только строки, где email не равен NULL — вернёт 800. Это важное отличие при работе с данными, где есть пропуски: путаница между этими функциями приводит к неверной оценке наполненности столбца.
Проверь себя · 1/3разбор после ответа
Что вернёт запрос
SELECT DISTINCT city, country FROM users, если в таблице есть повторяющиеся пары city-country?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям нужны только идентификатор пользователя `user_id` и дата `signup_at` из таблицы пользователей. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в нём нет `ORDER BY`?
- Все вопросы по «Основы SQL-запросов» →