一道Oracle子查询小练习

简介:

昨天晚上躺在床上看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关键字过滤重复,下面的方法用分组的方法实现。实现思想基本没变。


本文转自贺满博客园博客,原文链接:http://www.cnblogs.com/puresoul/archive/2010/07/12/1775652.html ,如需转载请自行联系原作者。

目录
相关文章
|
4月前
|
SQL Oracle 关系型数据库
JAVAEE框架数据库技术之12_oracle常用函数和高级查询子查询
JAVAEE框架数据库技术之12_oracle常用函数和高级查询子查询
69 0
JAVAEE框架数据库技术之12_oracle常用函数和高级查询子查询
|
6月前
Oracle-高级子查询
Oracle-高级子查询
26 0
|
SQL Oracle 关系型数据库
|
SQL 机器学习/深度学习 移动开发
Oracle多表查询,子查询,分页查询
🍅程序员小王的博客:程序员小王的博客 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 如有编辑错误联系作者,如果有比较好的文章欢迎分享给我,我会取其精华去其糟粕 🍅java自学的学习路线:java自学的学习路线
274 0
Oracle多表查询,子查询,分页查询
|
SQL Oracle 关系型数据库
Oracle中的分组查询、子查询、多表连接
Oracle中的分组查询、子查询、多表连接
223 0
Oracle中的分组查询、子查询、多表连接
|
SQL 移动开发 Oracle
6-5 Oracle表复杂查询 -子查询
子查询是指嵌入在其它sql语句中的select语句,也叫嵌套查询。
168 0
|
Oracle 关系型数据库
oracle学习60-oracle之高级子查询2
oracle学习60-oracle之高级子查询2
72 0
oracle学习60-oracle之高级子查询2
|
Oracle 关系型数据库
oracle学习72-oracle之单行函数之子查询课后练习2
oracle学习72-oracle之单行函数之子查询课后练习2
82 0
|
Oracle 关系型数据库
oracle学习61-oracle之高级子查询1
oracle学习61-oracle之高级子查询1
62 0
oracle学习61-oracle之高级子查询1
|
Oracle 关系型数据库
oracle学习59-oracle之高级子查询之课后练习
oracle学习59-oracle之高级子查询之课后练习
49 0
oracle学习59-oracle之高级子查询之课后练习