首页 > 解决方案 > 选择具有差异的对象在哪里

问题描述

我试图找到一种方法来运行它:

SELECT 
    s.system_number,
    s.total_points,
    p.licensed_points,
    SUM(p.licensed_points) - SUM(s.total_points) AS difference_points
FROM 
    server AS s 
    LEFT JOIN 
        practice AS p ON p.system_number = s.system_number 
WHERE 
    difference_points < 0

我的目标是仅选择差异点 < 0 的对象

请问有人知道怎么做吗?

谢谢

标签: mysql

解决方案


  • 在这里使用聚合函数Sum()没有Group By意义。你需要做一个Group Byon s.system_number
  • 然后,您可以使用Having子句来考虑difference_points小于 0 的情况。

请尝试以下操作:

SELECT 
    s.system_number,
    SUM(s.total_points),
    SUM(p.licensed_points),
    SUM(p.licensed_points) - SUM(s.total_points) AS difference_points
FROM 
    server AS s 
    LEFT JOIN 
        practice AS p ON p.system_number = s.system_number 
GROUP BY 
  s.system_number 
HAVING 
    difference_points < 0

推荐阅读