Eu tenho duas mesas, TableA
&TableB
Todos os dados das tabelas estão disponíveis aqui: db<>fiddle
TableB
contém o cenário aprovado/reprovado da seguinte forma:
Quero atualizar tableA
com dados de tableB
um determinado A_id
.
Estou esperando tableA
uma saída como:
Então, escrevi uma consulta atualizada para A_id=2
o seguinte:
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;
E verifiquei se TableA
os dados estão sendo atualizados corretamente.
Mas, a consulta acima tem 3 subconsultas diferentes para cada atualização de coluna.
Então, eu quero escrever a consulta atualizada da seguinte forma:
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
Mas, não está funcionando. Você pode me ajudar a fazer isso?
O erro está sendo exibido da seguinte forma:
Existe outra maneira de atualizar TableA
?
NB: Todos os dados/consultas das tabelas estão disponíveis aqui: db<>fiddle
Sua atualização atual tem vários problemas, o maior deles é que você parece estar usando a sintaxe de junção de atualização do SQL Server. A sintaxe de junção de atualização do MySQL faz a junção primeiro, seguida pelo conjunto. Além disso, os aliases que você usou eram inconsistentes e tinham problemas. A versão a seguir está funcionando como você esperava.
Demonstração
A propósito, dado que os dados
TableA
são derivados da fonteTableB
, você pode considerar criar uma visualização baseada no seuT0
CTE e chamá-la sempre que precisar ver os dados dessa maneira.A resposta alternativa é:
https://dbfiddle.uk/2y9O-TkK?highlight=2