• 一道Oracle子查询小练习


    一道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关键字过滤重复,下面的方法用分组的方法实现。实现思想基本没变。


    作者:Glen.He 
    出处:http://www.cnblogs.com/puresoul/ 
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    Redis知识点
    MySQL InnoDB存储引擎知识点
    Java BIO、NIO 背后的理论知识
    分布式锁 & 分布式事务
    Kafka监控与JMX
    集合类源码(八)Collection之Set(HashSet, LinkedHashSet, TreeSet,ConcurrentSkipListSet)
    Kafka 基础知识
    JDK SPI 、Spring SPI、Dubbo SPI机制
    给老子爬爬爬!2019国家统计局最新城乡划分代码
    Linux系统使用教程
  • 原文地址:https://www.cnblogs.com/abcd19880817/p/7210783.html
Copyright © 2020-2023  润新知