Таблица orders, нужно UPDATE поля amount на основе JOIN с products. Какой синтаксис корректен в PostgreSQL?
SQLmediummiddle
Варианты ответа
UPDATE orders o SET amount = p.price * o.qty FROM products p WHERE p.id = o.product_id — PostgreSQL использует FROM внутри UPDATE для подтягивания данных из других таблиц
UPDATE orders o JOIN products p ON o.product_id = p.id SET o.amount = p.price * o.qty — стандартный SQL-2008 синтаксис, работает во всех СУБД включая PostgreSQL 14+
WITH upd AS (SELECT * FROM orders JOIN products ...) UPDATE orders FROM upd SET amount — только через CTE-перезапись всей таблицы, прямого UPDATE JOIN в Postgres нет
UPDATE orders SET amount = (SELECT p.price FROM products p WHERE p.id = orders.product_id) * qty — только коррелированным подзапросом, иначе PostgreSQL бросит ошибку синтаксиса
Разбор ответа
Подробный разбор с объяснением «почему правильный ответ верный» и почему остальные неверны — после регистрации.
2475 вопросов с разбором, quiz-режим с проверкой, AI-собес и подготовка к интервью аналитика.