昨天晚上躺在床上看Oracle(最近在学习这个),室友说出个题目让我试试。题目如下:
有如下表结构,请选择出成绩为前三名的人的信息(如果成绩相同,则算并列),表名为test:
NAME GRADE
-------------------- ----------
kate 80
jenny 80
daring 85
agony 85
xxx 90
yyy 60
昨天大概想了下可以从以下几点考虑实现:
1、首先肯定要进行排序
2、子查询
3、由于Oracle中没有TopN,所以只能考虑用rownum伪列
4、由于可以有重复的成绩,考虑用distinct或者分组
经过测试,我的答案如下:
select * from test
where grade in (
select grade from (
select distinct grade from test
order by grade desc
)
where rownum < 4
)
order by grade desc;
或
select * from test
where grade in (
select grade from (
select grade from test
group by grade
order by grade desc
)
where rownum < 4
)
order by grade desc;
上面两种方法,思路大致差不多,只不过上面的用distinct关键字过滤重复,下面的方法用分组的方法实现。实现思想基本没变。