SUM(),GROUP BY和WHERE

时间:2016-05-09 20:01:51

标签: sql sql-server tsql

我有一张这样的表:

Title   | Version   | Condition | Count
-----------------------------------------------
Title1  | 1.0       | 1         | 10
Title1  | 1.1       | 2         | 5
Title1  | 1.1       | 2         | 10
Title1  | 1.1       | 1         | 10
Title2  | 1.0       | 2         | 10
Title2  | 1.5       | 1         | 5
Title2  | 1.5       | 2         | 5
Title3  | 1.5       | 2         | 10
Title3  | 1.5       | 1         | 10

我想总结" Count"的价值。对于每一行都有MAX()"版本"和"条件" = 2.我希望这是结果数据集:

Title   | Version   | Condition | Count
-----------------------------------------------
Title1  | 1.1       | 2         | 15
Title2  | 1.5       | 2         | 5
Title3  | 1.5       | 2         | 10

我可以获得"标题"的列表和MAX("版本")"条件" = 2:

SELECT DISTINCT Title, MAX(Version) AS MaxVer FROM TABLE
WHERE Condition = 2
GROUP BY Title

我不知道如何添加所有" Count" s。

2 个答案:

答案 0 :(得分:2)

试试这个:

SELECT t1.Title, t1.Version, t1.Condition, SUM([Count]) AS Count
FROM mytable AS t1
JOIN (
  SELECT Title, MAX(Version) AS max_version
  FROM mytable
  WHERE Condition = 2
  GROUP BY Title
) AS t2 ON t1.Title = t2.Title AND t1.Version = t2.max_version
WHERE t1.Condition = 2
GROUP BY t1.Title, t1.Version, t1.Condition

Demo here

答案 1 :(得分:1)

这只需要一次访问该表:

SELECT Title, Version, Condition, Count
FROM
 ( -- calculate all SUMs
   SELECT Title, Version, Condition, SUM(Count) AS Count,
      ROW_NUMBER() OVER (PARTITION BY Title ORDER BY Version DESC) AS rn
   FROM TABLE
   WHERE Condition = 2
   GROUP BY Title, Version, Condition
 ) AS dt
   -- and return only the row with the highest Version
WHERE rn = 1