Skip to content

Instantly share code, notes, and snippets.

@shiranuik
Created February 23, 2016 14:29
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save shiranuik/2ab16fcb3e0a6b86fd7b to your computer and use it in GitHub Desktop.
Save shiranuik/2ab16fcb3e0a6b86fd7b to your computer and use it in GitHub Desktop.
MysqlでSQL1文でランキング上位を取得
select rank,base.shain_number,base.name_kanji,base.uriage FROM
(select uriage,sumrot, @rank as rank ,cnt,@rank := @rank + cnt
From (select @rank := 1) as dummy,
(select ur2.kingaku as uriage,ur2.rot as sumrot,count(*) as cnt
from uriage ur2
where ur2.year = 2016 and ur2.term = 1
and ur2.rot >= 10
group by ur2.kingaku,rot order by ur2.kingaku desc,rot desc) as grpby
) as Ranking
join
(select sh.shain_number,sh.name_kanji,ur.kingaku as uriage,ur.rot
from uriage ur
inner join shain sh on sh.shain_number = ur.shain_number
where ur.year = 2016 and ur.term = 1
and ur.rot >= 10
) as base
on base.uriage = Ranking.uriage and base.rot = Ranking.sumrot
where rank <= 3
order by rank desc;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment