Oracle的一些经典SQL面试题
实例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面试题的更多相关文章
- 经典SQL面试题(转)
以下题目都在MySQL上测试可行,有疏漏或有更优化的解决方法的话欢迎大家提出,我会持续更新的:) 有三个表,如果学生缺考,那么在成绩表中就不存在这个学生的这门课程成绩的记录,写一段SQL语句,检索出每 ...
- 经典SQL面试题(转)
http://www.cnblogs.com/kcher90/archive/2013/03/13/2957932.html 有三个表,如果学生缺考,那么在成绩表中就不存在这个学生的这门课程成绩的记录 ...
- 经典sql面试题(学生表_课程表_成绩表_教师表)
转载:https://www.cnblogs.com/qixuejia/p/3637735.html 表架构 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cna ...
- [转帖]分享Oracle的四道经典面试题,值得收藏
分享Oracle的四道经典面试题,值得收藏 原创 波波说运维 2019-07-20 00:02:00 https://www.toutiao.com/i6713901660919300621/ 概述 ...
- Oracle经典SQL
最近本人整理了一些Oracle sql,现分享给大家,后续还会更新.如果有错误的地方,请指正,共同学习.贴上去的sql都是我测试过的,大家可以粘贴在自己的电脑上试试. 1.查询部门的名称,及最低收入雇 ...
- MySql_34道经典Sql试题
MySql_34道经典Sql试题 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/xiaouncle/article/details/799390 ...
- (转)经典SQL查询语句大全
(转)经典SQL查询语句大全 一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql s ...
- 浅谈c#的三个高级参数ref out 和Params C#中is与as的区别分析 “登陆”与“登录”有何区别 经典SQL语句大全(绝对的经典)
浅谈c#的三个高级参数ref out 和Params c#的三个高级参数ref out 和Params 前言:在我们学习c#基础的时候,我们会学习到c#的三个高级的参数,分别是out .ref 和 ...
- 经典sql语句大全,【转载】
经典SQL查询语句大全 一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql se ...
随机推荐
- 使用VisualSVN Server搭建SVNserver (Windows环境为例)
使用 VisualSVN Server来实现主要的 SVN功能则要比使用原始的 SVN和Apache相配合来实现源代码的 SVN管理简单的多,下面就看看详细的说明. VisualSVN Server的 ...
- Atitit 技术经理职责与流程表总结
Atitit 技术经理职责与流程表总结 1. (最重要) 理念 价值观建设 ***团队文化建设2 1.1. 加强跨项目组员沟通 ,防止重复劳动2 1.2. 活动聚餐2 2. (重要)方向建设 技术 ...
- Oracle---number数据类型
NUMBER ( precision, scale) precision表示数字中的有效位;如果没有指定precision的话,Oracle将使用38作为精度. 如果scale大于零,表示数字精确 ...
- Thrift 源码学习一——源码结构
Thrift 客户端与服务端的交互图 源码结构 传输层 TTransport: TTransport:客户端传输层抽象基础类,read.write.flush.close 等方法 TSocket 与 ...
- 【WPF】自定义形状的按钮Button
需求:做一个如下图所示的多边形按钮. <!-- 特殊形状的按钮 --> <Grid> <Polygon Points="0,0 140,0 190,42 140 ...
- STM32F103VET6 ADC采集64点做FFT变换
http://www.stmcu.org/module/forum/thread-598459-1-11.html http://bbs.21ic.com/icview-589756-1-1.html ...
- Java知多少(78)Java向量(Vector)及其应用
Vector(向量)是 java.util 包中的一个类,该类实现了类似动态数组的功能. 向量和数组相似,都可以保存一组数据(数据列表).但是数组的大小是固定的,一旦指定,就不能改变,而向量却提供了一 ...
- 如何停止和禁用Linux系统中的不需要的服务
从Linux中删除不需要的服务 在本文中,我们将讨论一些您不需要的不需要的应用程序和服务,但它们是在操作系统安装期间默认安装的,并且不知不觉地开始吃您的系统资源. 让我们首先知道使用以下命令在系统上运 ...
- Oracle垃圾数据清理相关问题 分类: Oracle 2015-08-06 11:14 12人阅读 评论(0) 收藏
垃圾数据清理,简单的说,就是删除不需要的那些数据,释放存储空间 最常用的就是delete命令.truncate命令,甚至是删除表空间重建,具体操作都很简单,不是本文的重点 下面,总结几个垃圾数据清理常 ...
- QT QQuickView嵌入到QT MDI中
在学习QT的过程中发现有一个特别炫酷的行星例子“planets”,有两种实现版本: 一种是基于Qt 3D QML(planets-qml),另一种则是基于Quick和强大的Three.js(plane ...