【问题标题】:filter postgresql query result过滤postgresql查询结果
【发布时间】:2012-04-20 15:55:34
【问题描述】:

我有多个表需要合并为一个。

SELECT name, SUM(money) AS MONEY FROM transactions
JOIN results ON transactions.id = results.id
JOIN more ON results.per_id = more.per_id
GROUP BY name

输出是人名(第一列)和人的钱(第二列)。

name | money
aaron  1220
mike   800
john   200
kate   600

现在我尝试按金额过滤结果,即为“Sum(money) > 500”的人显示结果

出于这个原因,我尝试输入“WHERE money > 500 GROUP BY name”,但输出错误(aaron 1000、mike 610 等)。

如何编写查询来过滤last/ending结果?

【问题讨论】:

    标签: sql postgresql filter


    【解决方案1】:
    Group By Name
    having sum(money) > 500
    

    编辑:“最后/结束结果”是什么意思?

    【讨论】:

    • 我尝试添加“GROUP BY name HAVING money > 500”但出现错误..问题是我从未使用过 SUM ().. 认为解决方案是如此接近。谢谢拉斐尔
    【解决方案2】:

    如果你想让SUM(money) 大于 500。那么你可以这样做:

    SELECT name, SUM(money) AS MONEY FROM transactions
    JOIN results ON transactions.id = results.id
    JOIN more ON results.per_id = more.per_id
    GROUP BY name
    HAVING SUM(money)>500
    

    【讨论】:

      猜你喜欢
      • 2022-10-14
      • 2019-12-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-12-15
      • 1970-01-01
      相关资源
      最近更新 更多