SUM列的HAVING子句

时间:2013-12-15 11:34:34

标签: sql hsqldb

我想在总和得到得分列的条件,但 HAVING得分=<如果我把它放在分组之后,则无效。那必须向我展示得分很高的项目。我正在使用hsqldb,出了什么问题?我得到'用户缺乏privelege或找不到对象:SCORE'

SELECT p.id, p.project_name, SUM(CASE r.type_code 
    WHEN 'GOOD' THEN  1 
    WHEN 'VERY_GOOD' THEN  1 
    WHEN 'BAD' THEN -1 
    WHEN 'VERY_BAD' THEN -1 
    ELSE 0 END) AS score
FROM record_project AS rp
JOIN project AS p ON p.id = rp.project_id 
JOIN record AS r ON r.id = rp.record_id 
GROUP BY p.id, p.project_name
HAVING score =< 1        <<<---- wrong?!
ORDER BY score DESC LIMIT 1

2 个答案:

答案 0 :(得分:3)

您应该使用整个计算列

SELECT p.id, p.project_name,
       SUM(CASE WHEN r.type_code IN ('GOOD','VERY_GOOD') THEN 1
                WHEN r.type_code IN ('BAD','VERY_BAD') THEN -1
                ELSE 0 END) score
FROM   record_project AS rp
       JOIN project AS p ON p.id = rp.project_id 
       JOIN record AS r ON r.id = rp.record_id 
GROUP  BY p.id, p.project_name
HAVING SUM(CASE WHEN r.type_code IN ('GOOD','VERY_GOOD') THEN 1
                WHEN r.type_code IN ('BAD','VERY_BAD') THEN -1
                ELSE 0 END) <= 1
ORDER  BY score DESC 
-- LIMIT  1

答案 1 :(得分:2)

您可以将HAVING作为WHERE纳入子查询:

SELECT * FROM ( 
  SELECT p.id, p.project_name, SUM(CASE r.type_code 
    WHEN 'GOOD' THEN  1 
    WHEN 'VERY_GOOD' THEN  1 
    WHEN 'BAD' THEN -1 
    WHEN 'VERY_BAD' THEN -1 
    ELSE 0 END) AS score
  FROM record_project AS rp
  JOIN project AS p ON p.id = rp.project_id 
  JOIN record AS r ON r.id = rp.record_id 
  GROUP BY p.id, p.project_name) x
WHERE score =< 1
ORDER BY score DESC
LIMIT 1