Первый 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 заполнятся значением NULL
DЗапрос объединит все столбцы из обоих запросов в один широкий результирующий набор
Правильный ответ. Для 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 в Telegram

Ещё вопросы по теме «Основы SQL-запросов»