我正在创建一个体育页面,我已经到了无法解决自己的问题的地步。
我的问题是,我不知道如何在每一场比赛后分别存储每支球队的位置。以下是我想要实现的目标:
为了创建排名表,我有两个表:
俱乐部: id_clubs,名称
结果: matchid,matchday,hometeam,awayteam,homegoals,awaygoals,date,id_league
从结果表中,我创建了我的排名表,其设置如下:
SELECT
name AS Team,
Sum(P) AS P,
Sum(W) AS W,
Sum(D) AS D,
Sum(L) AS L,
SUM(F) as F,
SUM(A) AS A,
SUM(GD) AS GD,
SUM(Pts) AS Pts
FROM (
SELECT *,
hometeamid Team,
1 P,
IF(homegoal > awaygoal,1,0) W,
IF(homegoal = awaygoal,1,0) D,
IF(homegoal < awaygoal,1,0) L,
homegoal F,
awaygoal A,
homegoal-awaygoal GD,
CASE WHEN homegoal > awaygoal THEN 3
WHEN hometeam = awaygoal THEN 1
ELSE 0
END PTS
FROM results
WHERE id_league = '$leagueid'
AND homegoal IS NOT NULL
AND awaygoal IS NOT NULL
UNION ALL
SELECT *,
awayteamid,
1,
IF(homegoal < awaygoal,1,0),
IF(homegoal = awaygoal,1,0),
IF(homegoal > awaygoal,1,0),
awaygoal,
homegoal,
awaygoal-homegoal GD,
CASE WHEN homegoal < awaygoal THEN 3
WHEN homegoal = awaygoal THEN 1
ELSE 0
END
FROM results
WHERE id_league = '$leagueid'
AND awaygoal IS NOT NULL
AND homegoal IS NOT NULL
) AS tot
JOIN clubs t ON tot.Team=t.id_clubs
GROUP BY Team
ORDER BY
SUM(Pts) desc,
SUM(GD) desc
希望有人能给出一些建议或解决方案。
发布于 2013-04-29 11:35:48
如果您的问题是从结果表中检索订单号,这里有一个类似的讨论,这可能正是您所需要的:MySQL - Get row number on select
要选择第一个n
匹配,您可以在按匹配id分组后执行LIMIT n
。
https://stackoverflow.com/questions/16261560
复制相似问题