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