У меня есть две таблицы: 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
Псевдонимы во втором запросе на обновление неверны. Это тот самый код, который вы используете, и какое именно сообщение об ошибке?
Рассматривали ли вы вместо этого создание представления? Всегда будет актуально.
@TimBiegeleisen Пожалуйста, проверьте запрос db<>fiddle: dbfiddle.uk/NYNlAwEo Также обновите сообщение об ошибке
вы можете обновить с помощью соединения - заголовок статьи 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
когда я попробовал тот же запрос на сервере oracle-sql, он не работал... livesql.oracle.com/apex/livesql/s/b8xorca6gq98jzctmproo6aw8 Есть ли у вас какие-либо предложения?
В вашем текущем обновлении есть несколько проблем, самая большая из которых заключается в том, что вы, похоже, используете синтаксис объединения обновлений 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, большое спасибо
когда я попробовал тот же запрос на сервере oracle-sql, он не работал... livesql.oracle.com/apex/livesql/s/b8xorca6gq98jzctmproo6aw8 Есть ли у вас какие-либо предложения?
@ArtBindu Не используйте тег MySQL, если у вас есть вопросы об Oracle
Альтернативный ответ:
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
Спасибо @Dipcoder за помощь в решении сервера oracle-sql.
Это мой справочный запрос (обновить таблицу путем присоединения): stackoverflow.com/questions/1746125/…