【发布时间】:2012-01-22 19:52:11
【问题描述】:
我有这个 SQL 查询,它执行 GROUP BY 以将所有包含相同 Player_id 但不相同 Game_id 的行合并在一起:
SELECT p.Player_id,
p.Name,
p.Position,
SUM(s.Goals) AS goalsb,
SUM(s.Assists) AS assistsb,
SUM(s.Points) AS pointsb
FROM Dim_Player AS p
INNER JOIN Fact_Statistics AS s ON s.Player_id = p.Player_id
GROUP BY p.Player_id, p.Name, p.Position
ORDER BY pointsb DESC, goalsb DESC
我想要做的是每次 GROUP BY 将一行与另一行合并以创建一个名为“已玩游戏”的新列时植入一个 COUNT。示例:
Player_id Game_id goalsb
8470598 465 1
8470598 435 1
这将与上面的 SQL 查询组合在一起成为:
Player_id goalsb
8470598 2
但我想要这个:
Player_id goalsb Games_played
8470598 2 2
【问题讨论】:
-
不确定您是否理解这个问题,但在您的 SELECT 语句中添加
COUNT (DISTINCT Game_Id)是否可以解决问题? -
那行得通。我在做 COUNT (*)
-
我会用它来回答:)