微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在WHERE子句中使用聚合进行SQL更新

我正在尝试设置列日期的日期字段,让表示表1中的’10/11/2012′,当表2的所有金额的总和与该id相关(通过fk_id)= 0.这就是我的意思:

从:

表格1

id    date
    1     10/11/2011
    2      
    3     10/12/2011

表2

fk_id    amount
    1     200
    2     0
    2     0
    3     100

至:

表格1

id    date
    1     10/11/2011
    2     10/11/2012
    3     10/12/2011

表2

fk_id    amount
    1     200
    2     0
    2     0
    3     100

这就是我目前所拥有的:

update table1
set date = '10/11/2012
FROM table1 inner join table 2 on table1.id = table2.fk_id
HAVING sum(table2.amount) = 0

有人可以帮帮我吗?

解决方法

UPDATE table1 
SET date = '10/11/2012' 
FROM table1 
WHERE id IN (SELECT FK_ID FROM table2 GROUP BY FK_ID HAVING SUM(Amount)=0)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐