Обновить несколько столбцов таблицы SQL на основе другой таблицы

У меня есть две таблицы: TableA и TableB.

Все данные таблиц доступны здесь: db<>fiddle

TableA следующим образом:

TableB содержит сценарий пройден/не пройден следующим образом:

Я хочу обновить tableA данными tableB для конкретного A_id.

Я ожидаю вывода tableA как:

Итак, я написал обновленный запрос для A_id=2 следующим образом:

UPDATE  TableA
SET     
    total_count = (SELECT COUNT(A_id) AS total_count 
                FROM TableB WHERE A_id = 2),
    pass_count = (SELECT COUNT(CASE WHEN(isPassed = 'Y') THEN 1 END) as pass_count 
                FROM TableB WHERE A_id = 2),
    fail_count = (SELECT COUNT(CASE WHEN(isPassed = 'N') THEN 1 END) as fail_count 
                FROM TableB WHERE A_id = 2)
WHERE   A_id = 2;

И проверил TableA, данные обновляются правильно.


Но приведенный выше запрос имеет 3 разных подзапроса для каждого обновления столбца.
Итак, я хочу написать обновленный запрос следующим образом:

WITH T0 AS (
    SELECT A_id,
        COUNT(A_id) AS TOTAL_SCENARIOS_COUNT,
        COUNT(CASE WHEN(isPassed = 'Y') THEN 1 END) as PASS_SCENARIOS_COUNT,
        COUNT(CASE WHEN(isPassed = 'N') THEN 1 END) as FAIL_SCENARIOS_COUNT
    from RT_TEST_RUN_SCENARIO
    GROUP BY A_id    
    HAVING A_id = 4779
)
UPDATE  tableA
SET     
    tableA.total_count = t0.total_count,
    tableA.pass_count = t0.pass_count,
    tableA.fail_count = t0.fail_count
FROM tableA INNER JOIN T0
ON tableA.A_id = T0.A_id

Но это не работает. Можете ли вы мне помочь, как это сделать?
Ошибка отображается следующим образом:

Есть ли другой способ обновить TableA?

NB: все данные/запросы таблиц доступны здесь: db<>fiddle

Это мой справочный запрос (обновить таблицу путем присоединения): stackoverflow.com/questions/1746125/…

ArtBindu 02.09.2024 15:53

Псевдонимы во втором запросе на обновление неверны. Это тот самый код, который вы используете, и какое именно сообщение об ошибке?

Tim Biegeleisen 02.09.2024 16:00

Рассматривали ли вы вместо этого создание представления? Всегда будет актуально.

jarlh 02.09.2024 16:00

@TimBiegeleisen Пожалуйста, проверьте запрос db<>fiddle: dbfiddle.uk/NYNlAwEo Также обновите сообщение об ошибке

ArtBindu 02.09.2024 16:04

вы можете обновить с помощью соединения - заголовок статьи MySQL UPDATE JOIN Пример с LEFT JOIN например UPDATE TableA as A JOIN (SELECT Statement from TableB) AS B ON A.id = B.id SET a.column = b.column

Usama 02.09.2024 16:11

когда я попробовал тот же запрос на сервере oracle-sql, он не работал... livesql.oracle.com/apex/livesql/s/b8xorca6gq98jzctmproo6aw8 Есть ли у вас какие-либо предложения?

ArtBindu 02.09.2024 18:14
ReactJs | Supabase | Добавление данных в базу данных
ReactJs | Supabase | Добавление данных в базу данных
Это и есть ваш редактор таблиц в supabase.👇
Понимание Python и переход к SQL
Понимание Python и переход к SQL
Перед нами лабораторная работа по BloodOath:
3
6
50
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

В вашем текущем обновлении есть несколько проблем, самая большая из которых заключается в том, что вы, похоже, используете синтаксис объединения обновлений SQL Server. Синтаксис соединения при обновлении MySQL сначала выполняет соединение, а затем набор. Кроме того, используемые вами псевдонимы были непоследовательными и вызывали проблемы. Следующая версия работает так, как вы ожидали.

WITH T0 AS (
    SELECT
        A_id,
        COUNT(*) AS total_count,
        SUM(isPassed = 'Y') AS pass_count,
        SUM(isPassed = 'N') AS fail_count
    FROM TableB
    GROUP BY A_id
)

UPDATE TableA a
INNER JOIN T0
    ON a.A_id = T0.A_id
SET     
    a.total_count = T0.total_count,
    a.pass_count = T0.pass_count,
    a.fail_count = T0.fail_count;

Демо

Кстати, учитывая, что данные в TableA получены из источника TableB, вы можете просто создать представление на основе вашего T0 cte, а затем вызывать его всякий раз, когда вам нужно просмотреть данные таким образом.

потрясающе @TimBiegeleisen, большое спасибо

ArtBindu 02.09.2024 17:22

когда я попробовал тот же запрос на сервере oracle-sql, он не работал... livesql.oracle.com/apex/livesql/s/b8xorca6gq98jzctmproo6aw8 Есть ли у вас какие-либо предложения?

ArtBindu 02.09.2024 18:14

@ArtBindu Не используйте тег MySQL, если у вас есть вопросы об Oracle

ysth 02.09.2024 19:31

Альтернативный ответ:

UPDATE TableA
JOIN (
    SELECT A_id,
        COUNT(*) AS total_count,
        SUM(isPassed = 'Y') AS pass_count,
        SUM(isPassed = 'N') AS fail_count
    FROM TableB
    GROUP BY A_id
    -- HAVING A_id = 3
) T0
   ON TableA.A_id = T0.A_id
SET     
    TableA.total_count = T0.total_count,
    TableA.pass_count = T0.pass_count,
    TableA.fail_count = T0.fail_count
WHERE TableA.A_id = T0.A_id;

SELECT * FROM TableA;

https://dbfiddle.uk/2y9O-TkK?highlight=2

Спасибо за альтернативное решение @Dipcoder

ArtBindu 02.09.2024 21:15

Спасибо @Dipcoder за помощь в решении сервера oracle-sql.

ArtBindu 02.09.2024 21:15

Другие вопросы по теме