Что сделает запрос INSERT INTO archive (order_id, amount, status) SELECT order_id, amount, status FROM orders WHERE status = 'completed'?
AЗапрос вставит в
archive только столбцы, совпадающие по имени с таблицей ordersBЗапрос вызовет ошибку, потому что
INSERT и SELECT нельзя использовать в одном запросеCЗапрос скопирует все строки из
orders в archive без применения условия по статусуDЗапрос вставит в
archive только заказы со статусом 'completed' из таблицы ordersПравильный ответ.
INSERT INTO ... SELECT копирует результат запроса SELECT в указанную таблицу.Разбор
Конструкция INSERT INTO ... SELECT берёт результат выборки и вставляет его в целевую таблицу. Здесь SELECT фильтрует заказы со статусом 'completed' и выбирает три столбца. Эти строки вставляются в таблицу archive в указанные столбцы. Условие WHERE применяется к исходным данным, поэтому копируются не все заказы, а только завершённые.
Проверь себя · 1/3разбор после ответа
Вы делаете пагинацию так:
SELECT product_id FROM products LIMIT 20 OFFSET 20. В чём главный риск такого подхода для аналитической витрины/интерфейса, если нет ORDER BY?Ещё вопросы по теме «Основы 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-запросов» →