8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

根据另一个表更新 SQL 表的多个列

Hekima 1月前

17 0

我有两个表,TableA 和 TableB,所有表数据均可在此处获得:db<>fiddleTableA 如下:TableB 包含通过/失败的情况如下:我想使用以下代码更新 tableA...

我有两张桌子, TableA & TableB

所有表格数据均可在此处获取:db<>fiddle

TableA 如下:
enter image description here

TableB 包含以下通过/失败的场景:
enter image description here

我想更新 tableA 特定 tableB 数据 A_id .

我期望 tableA 输出如下:
updated_table

因此,我编写了更新的查询 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

但是,它不起作用。你能帮我怎么做吗?
错误显示如下:
enter image description here

还有其他方法可以更新吗 TableA

注意:所有表格数据/查询都可以在这里找到:db<>fiddle

帖子版权声明 1、本帖标题:根据另一个表更新 SQL 表的多个列
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Hekima在本站《mysql》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 您的第二个更新查询中的别名是错误的。这是您正在运行的实际代码吗?确切的错误消息是什么?

  • @TimBiegeleisen 请检查 db<>fiddle 查询:

  • 您当前的更新存在多个问题,最大的问题是您似乎使用了 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 创建一个视图,然后在需要以这种方式查看数据时调用它。

  • 当我在 oracle-sql 服务器中尝试相同的查询时,它不起作用...livesql.oracle.com/apex/livesql/s/b8xorca6gq98jzctmproo6aw8 您有什么建议吗?

  • @ArtBindu 当您对 Oracle 有疑问时,请不要使用 MySQL 标签

  • x w 1月前 0 只看Ta
    引用 7

    替代答案是:

    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

返回
作者最近主题: