Первый SELECT возвращает два столбца name, email, а второй — три столбца name, email, phone. Что произойдёт при SELECT name, email FROM users UNION ALL SELECT name, email, phone FROM contacts?
AЗапрос вызовет ошибку, потому что количество и типы столбцов в обоих
SELECT должны совпадатьBЗапрос выполнится успешно: лишние столбцы второго
SELECT будут обрезаны автоматическиCЗапрос выполнится успешно: недостающие столбцы первого
SELECT заполнятся значением NULLDЗапрос объединит все столбцы из обоих запросов в один широкий результирующий набор
Правильный ответ. Для
UNION / UNION ALL количество столбцов и их типы должны совпадать во всех объединяемых запросах.Разбор
SQL требует, чтобы все части UNION или UNION ALL возвращали одинаковое количество столбцов с совместимыми типами. Если первый SELECT возвращает 2 столбца, а второй — 3, запрос завершится ошибкой. Чтобы это исправить, нужно либо убрать лишний столбец из второго запроса, либо добавить NULL AS phone в первый.
Проверь себя · 1/3разбор после ответа
У пользователя
price = 100 и discount = NULL. Что вернёт выражение SELECT price + discount FROM products для этой строки?Ещё вопросы по теме «Основы SQL-запросов»
- В таблице `users` нужно выбрать только активных пользователей из России или Казахстана. Какой `WHERE` соответствует требованию?
- Для отчёта по регистрациям вам нужны только `user_id` и `signup_at` из таблицы `users`. Какой запрос лучше соответствует задаче и не тянет лишние поля?
- Нужно получить 20 самых новых событий из таблицы `events` (по времени `event_time`) и показать их в выдаче сверху. Какой запрос верный?
- Вы строите выдачу «последние заказы» и используете `LIMIT 50`. Поле `created_at` не уникально (много заказов в одну секунду). Какой `ORDER BY` лучше, чтобы порядок был детерминированным?
- Что можно корректно утверждать про результат запроса `SELECT user_id FROM users LIMIT 10`, если в запросе нет `ORDER BY`?
- Все вопросы по «Основы SQL-запросов» →