实例1:测试数据:

create table nba(

team   varchar2(20),

year number(4)

)

SQL> select * from nba;

TEAM                  YEAR

-------------------- -----

活塞                  1990

公牛                  1991

公牛                  1992

公牛                  1993

火箭                  1994

火箭                  1995

公牛                  1996

公牛                  1997

公牛                  1998

马刺                  1999

湖人                  2000

湖人                  2001

湖人                  2002

马刺                  2003

活塞                  2004

马刺                  2005

热火                  2006

马刺                  2007

凯尔特人              2008

湖人                  2009

湖人                  2010

21 rows selected

请写出一条 SQL 语句,查询出在此期间连续获得冠军的有哪些,其连续的年份的起止时间是多少,结果如下:

TEAM BEGIN END
---------------
公牛 1991 1993
火箭 1994 1995
公牛 1996 1998
湖人 2000 2002
湖人 2009 2010

求解:

SQL> select team, min(t2y), max(t1y)

2    from (select t2.team, t2.year as t2y, t1.year as t1y

3            from nba t1, nba t2

4           where t1.team = t2.team

5             and t1.year = (t2.year + 1)) t

6   group by t.team, (t.t1y - rownum);

TEAM                   MIN(T2Y)   MAX(T1Y)

-------------------- ---------- ----------

公牛                       1996       1998

湖人                       2009       2010

湖人                       2000       2002

公牛                       1991       1993

火箭                       1994       1995

分析:这个SQL要做的有两件事:

1)求出连续获得冠军的team

2)求出起止年份

关系:根据分析1可知,存在关系team相同的球队(year=year+1),满足这个关系的球队即是连续获得冠军的球队。可以得到SQL如下:

SQL> select t2.team, t2.year as t2y, t1.year as t1y

2    from nba t1, nba t2

3   where t1.team = t2.team

4     and t1.year = (t2.year + 1);

TEAM                   T2Y   T1Y

-------------------- ----- -----

公牛                  1991  1992

公牛                  1992  1993

火箭                  1994  1995

公牛                  1996  1997

公牛                  1997  1998

湖人                  2000  2001

湖人                  2001  2002

湖人                  2009  2010

8 rows selected

sql中t2y字段表示球队获得冠军每连续两行之间的最小年份,t1y为连续两行记录间的最大年份,最终满足分析1,和2的结果集到此都可以从这个临时表中取得了。

下面我们需要对这个临时表做一个分组,即连续获得冠军的球队我们只需要1行记录用做显示,分组字段是什么呢?观察临时表结构,这里我们采用(team,t1y-rownum)作为分组条件,这样连续获得冠军的球队team就可以用一行显示了。那么我们还差起止年份需要处理一下,就可以出具最终的查询结果了!从临时表结构可以看出通过(team,t1y-rownum)分组后,可以由t2y字段我们求出开始年份,即(min(t2y)),可以由t1y字段求出结止年份,即(max(t1y))!继续处理SQL如下:

SQL> select t.team, min(t2y), max(t1y)

2    from (select t2.team, t2.year as t2y, t1.year as t1y

3            from nba t1, nba t2

4           where t1.team = t2.team

5             and t1.year = (t2.year + 1)) t

6   group by t.team, t1y - rownum

7   order by min(t2y);

TEAM                   MIN(T2Y)   MAX(T1Y)

-------------------- ---------- ----------

公牛                       1991       1993

火箭                       1994       1995

公牛                       1996       1998

湖人                       2000       2002

湖人                       2009       2010

总结一下,对于这套面试题,对于DBA出身的我,没有处理过类似问题,如果是我遇到了,估计在纸上是写不出来,但是自己处理,是可以求出如上结果的。所以写SQL是一个循序渐进的过程,不是一蹴而就的结果。

Oracle的一些经典SQL面试题的更多相关文章

  1. 经典SQL面试题(转)

    以下题目都在MySQL上测试可行,有疏漏或有更优化的解决方法的话欢迎大家提出,我会持续更新的:) 有三个表,如果学生缺考,那么在成绩表中就不存在这个学生的这门课程成绩的记录,写一段SQL语句,检索出每 ...

  2. 经典SQL面试题(转)

    http://www.cnblogs.com/kcher90/archive/2013/03/13/2957932.html 有三个表,如果学生缺考,那么在成绩表中就不存在这个学生的这门课程成绩的记录 ...

  3. 经典sql面试题(学生表_课程表_成绩表_教师表)

    转载:https://www.cnblogs.com/qixuejia/p/3637735.html 表架构 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cna ...

  4. [转帖]分享Oracle的四道经典面试题,值得收藏

    分享Oracle的四道经典面试题,值得收藏 原创 波波说运维 2019-07-20 00:02:00 https://www.toutiao.com/i6713901660919300621/ 概述 ...

  5. Oracle经典SQL

    最近本人整理了一些Oracle sql,现分享给大家,后续还会更新.如果有错误的地方,请指正,共同学习.贴上去的sql都是我测试过的,大家可以粘贴在自己的电脑上试试. 1.查询部门的名称,及最低收入雇 ...

  6. MySql_34道经典Sql试题

    MySql_34道经典Sql试题   版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/xiaouncle/article/details/799390 ...

  7. (转)经典SQL查询语句大全

    (转)经典SQL查询语句大全 一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql s ...

  8. 浅谈c#的三个高级参数ref out 和Params C#中is与as的区别分析 “登陆”与“登录”有何区别 经典SQL语句大全(绝对的经典)

    浅谈c#的三个高级参数ref out 和Params   c#的三个高级参数ref out 和Params 前言:在我们学习c#基础的时候,我们会学习到c#的三个高级的参数,分别是out .ref 和 ...

  9. 经典sql语句大全,【转载】

    经典SQL查询语句大全   一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql se ...

随机推荐

  1. Bash 中的特殊字符大全【转】

    Linux下无论如何都是要用到shell命令的,在Shell的实际使用中,有编程经验的很容易上手,但稍微有难度的是shell里面的那些个符号,各种特殊的符号在我们编写Shell脚本的时候如果能够用的好 ...

  2. ipa重签名

    为什么要研究重签名问题?将程序打包成ipa包后,ipa包中会包含Provisioning Profile和_CodeSignature等文件,里面包含了对整个ipa的签名信息. 一旦改动ipa中的不论 ...

  3. redis竞汰数据同步问题解决

    Redis 面试的时候遇到过问Redis是如何解决“竞态条件”的,相关知识点总结一下. 乐观锁 所谓竞态条件,举个例子,一个代表点击数的数值hitcount,每个客户点击一次则+1. 没有事务的时候, ...

  4. npm WARN unmet dependency错误解决方法

    在MAC上安装webpack以及reactjs等其它组件时,安装太慢卡住不动,直接ctrl+c终止后,再npm install后出npm WARN unmet dependency错误,npm cac ...

  5. java.lang.String.regionMatches方法使用

    regionMatches(boolean ignoreCase,int toffset,String other,int ooffset,int len): regionMatches(int to ...

  6. 【SpringMVC学习07】SpringMVC中的统一异常处理

    我们知道,系统中异常包括:编译时异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发.测试通过手段减少运行时异常的发生.在开发中,不管是dao层 ...

  7. 如何在wiced平台上编译,运行智能彩灯 实时控制彩灯的色调和开关

    https://github.com/WildDogTeam/demo-c-rgblight/tree/master/src/device 恢复出厂的GPIO口在demo_platform.h声明为W ...

  8. Qt动态库静态库的创建、使用、多级库依赖、动态库改成静态库等详细说明

    本文描述的是windows系统下,通过qtcreator在pro文件中添加动态库与静态库的方法: 1.添加动态库(直接添加动态库文件.dll,非子项目) 通过qtcreator创建动态库的方法就不在此 ...

  9. FPGA编程—组合逻辑编码器等verilog实现

    本篇博客主要实现对组合逻辑电路的一些常用模块的实现.组合逻辑中,包括译码器,编码器,输入输出选择器,数值比较器,算法单元等.  先来实现编码器,最常用的8-3编码器,这里先讲一下要用到的case ,c ...

  10. 多线程开发之一 NSThread

    每个 iOS 应用程序都有个专门用来更新显示 UI 界面.处理用户的触摸事件的主线程,因此不能将其他太耗时的操作放在主线程中执行,不然会造成主线程堵塞(出现卡机现象),带来不好的用户体验. 一般的解决 ...