这是使用 MYSQL
我的问题如下。我有一个棒球数据库,在那个棒球数据库中有一个主表,其中列出了每个曾经打过球的球员。还有一个击球台,可以跟踪每个球员的击球数据。我创建了一个将这两者结合在一起的视图;因此masterplusbatting
表。我现在想找到自棒球开始以来每十年中 HR 最高的击球手。这是我尝试过的。
select f.yearID, truncate(f.yearid/10,0) as decade,f.nameFirst, f.nameLast, f.HR
from (
select yearID, max(HR) as HOMERS
from masterplusbatting group by yearID
)as x inner join masterplusbatting as f on f.yearID = x.yearId and f.HR = x.HOMERS
group by decade
您可以看到我截断了 yearID 以获取187, 188, 189
etc 而不是1897, 1885,
. 然后我按十年分组,认为它会给我每十年最高的值,但它没有返回正确的值。例如,它给了我 Adrian Beltre 在 2004 年的 48 HR,但每个人都知道 Barry Bonds 在 2001 年达到了 73 HR。谁能给我一些建议?