超经典SQL题:做完这4道面试题你就过关了
http://www.itongji.cn/detail?type=99993193
很多程序员视 SQL 为洪水猛兽。SQL 是一种为数不多的声明性语言,它的运行方式完全不同于我们所熟知的命令行语言、面向对象的程序语言、甚至是函数语言(尽管有些人认为 SQL 语言也是一种函数式语言)。
第一题
1.现有如下学生成绩表st_score:
将上表转换为如下所示表,需满足以下要求:
①每一个st_id仅存在一行数据;
②成绩出现重复时选最高成绩;
③与下表字段顺序统一,字段名可不同;
④按照st_id升序排列;
⑤一条语句(只有一个分号)查询且没有出现基本语法错误。
注:无法实现行转列则为0分,使用一条一条结果用union连接也是0分,以上要求每个点2分
参考代码
select st_id,
name,
gender,
max(case when lesson = 'math' then score else 0 end) as mt_score,
max(case when lesson = 'Chinese' then score else 0 end) as chi_score,
max(case when lesson = 'English' then score else 0 end) as eng_score
from st_score
group by st_id,name,gender
order by st_id;
解析
case when语句是本题的核心,也是行转列这类题目的核心部分,题目要求①要求一个st_id仅存在一条数据,所以这里还需要配合聚合函数使用,用case when语句作为子查询,主查询再进行合并也是可以的,只是会多一个步骤。
要求②中已经明确要求“成绩出现重复时选“最高成绩”,所以表中是有可能出现重复值的,这里只能使用max()函数,如果这里已经明确说明不会出现重复值,就可以用sum()、max()、min()这样的聚合函数。
第二题
2.现已将上表查询的结果保存为新表new_score,根据new_score表查询出满足以下条件的结果:
①语数英三门课程的成绩都排在前五(包含第五);
②条件①中为单科成绩排名,从高到低排列,排名连续,成绩相同时采用并列排名;
③字段顺序同下表;
④结果按照总成绩从高到低排列;
⑤一条语句(只有一个分号)查询且没有出现基本语法错误。
注:使用一条一条结果用union连接则为0分,以上要求每个点2分
最终显示结果:
参考代码
select st_id,
name,
mt_score,
chi_score,
eng_score,
total_score
from (
select st_id,
name,
mt_score,
dense_rank() over(order by mt_score DESC) as rn_math,
chi_score,
dense_rank() over(order by chi_score DESC) as rn_chi,
eng_score,
dense_rank() over(order by eng_score DESC) as rn_eng,
mt_score + chi_score + eng_score as total_score
from new_score
) t
where rn_math <= 5 and rn_chi <= 5 and rn_eng <=5
order by total_score desc;
解析
本题考察的是窗口函数中row_number、rank、dense_rank的分辨和使用,根据本题要求②,这里需要使用dense_rank函数,并且顺序要从高到低排列,还需要用到order by desc;
有的可能会使用order by配合limit来解决排名问题,然后再进行表关联选择同时满足条件的数据,都没有问题,但是逻辑上会更复杂一些,计算过程也会更多一些。
第三题
3.现有某地近15日天气预报数据如下wr表所示:
按照上表写出一条建表语句,要求(每个点2分):
① id字段为整型数据,主键约束,自增;
② dt字段为日期格式,非空;
③ weather字段为可变长度字符串,最大长度为30,非空;
④ min_tem与max_tem字段为整型数据,最大长度为5,非空;
⑤ 无拼写错误,无其他基本语法错误。
参考代码
create table wr(
id int primary key auto_increment,
dt date not null,
weather varchar(30) not null,
min_tem int(5) not null,
max_tem int(5) not null
);
解析
本道题考察的是建表语句的写法,之所以放在这里考察,主要是为了防止大家在学习各种select查询技巧的同时,不要忘记最开始学的内容,虽然约束部分在课程里没有讲,但是在“爱数据学院”“互动社区”栏目下面有这部分内容的扩展喔,同时也有很多其他拓展知识,多多利用啊。
在这里还有人把insert用来建表我是没想到的,insert是插入数据的,create是新建数据库或者数据表的,这个可不能搞混了。
注:作为会SQL“增删改查”的你,当面试官问你建表语句怎么写,忘记了可就尴尬了~
第四题
4.根据wr表查询出连续3天以上(包含3天)都下雨(rain)的日期、天气、最高最低温度,字段顺序如下表所示:
注:思路逻辑正确但无法写出代码实现功能可得4分,代码逻辑完整和正确但代码最终无法实现功能可得8分,出现基本语法错误一处扣1分,最多扣4分,使用一条一条结果用union连接不得分。(能写出代码的同学尽量写出完整代码,并写出关键的注释来体现出思考逻辑,写不出代码的同学尽量表述出自己清晰的思路逻辑,尽可能的争取得分,能得一分是一分~)
解析
第一步:在这里需要借助一下辅助列:具体是用总的序号(rn)减去根据天气排的序号(rn_w)得到一个差值D_value,结果如下图,可以看到颜色相同的就是同一天气连续的的行(在这里rn列跟rn_w主要是为了方便大家理解,用熟悉之后可以不用展示出来):
参考代码
select dt,
weather,
min_tem,
max_tem,
ROW_NUMBER() over(order by dt) rn,
ROW_NUMBER() over(PARTITION by weather order by dt) rn_w,
ROW_NUMBER() over(order by dt) - ROW_NUMBER() over(PARTITION by weather order by dt) as D_value
from wr
order by dt;
第二步:再根据计算出来的D_value来计算连续的天(次)数,结果如下图:
参考代码
select dt,
weather,
min_tem,
max_tem,
count(1) over(partition by weather,D_value) as times
from (
select dt,
weather,
min_tem,
max_tem,
ROW_NUMBER() over(order by dt) rn,
ROW_NUMBER() over(PARTITION by weather order by dt) rn_w,
ROW_NUMBER() over(order by dt) - ROW_NUMBER() over(PARTITION by weather order by dt) as D_value
from wr
) D_wr
order by dt;
最后一步:直接用where条件来筛选出连续3天以上(包含3天)都下雨(rain)的结果:
参考代码
select dt,
weather,
min_tem,
max_tem
from (
select dt,
weather,
min_tem,
max_tem,
count(1) over(partition by D_wr.weather,D_wr.D_value) as times
from (
select dt,
weather,
min_tem,
max_tem,
ROW_NUMBER() over(order by dt) rn,
ROW_NUMBER() over(PARTITION by weather order by dt) rn_w,
ROW_NUMBER() over(order by dt) - ROW_NUMBER() over(PARTITION by weather order by dt) as D_value
from wr
) D_wr
) times_wr
where times>=3 and weather = 'rain';
说在最后
- 考点:聚合函数、case when、子查询、窗口函数等
- 主要涉及到case when语句实现行转列,窗口函数解决不同维度的Top问题和连续性问题。
- 考察同学们的审题是否细致、考查理解业务的能力
- 将实际业务需求转换成构建SQL语句、并得到分析结果的能力
超经典SQL题:做完这4道面试题你就过关了相关推荐
- sql max同一行_超经典SQL题 | 做完这4道面试题你就过关了
- 点击上方"爱数据学习社"关注我们吧! -文末领取[SQL数据分析常用语句]上篇文章→:SNA分析法是什么?KOL投放价值评估! 题目解析 | 爱数据青林 内容来源 | 爱数据学 ...
- 经典SQL题练习(MySQL版)
原题链接:超经典SQL练习题,做完这些你的SQL就过关了 原题中的答案存在一些错误的地方并且使用的是SQL SERVER,本解法采用的是MYSQL,答案也可能存在部分思虑不周的地方,可以共同探讨. 建 ...
- 深夜小酌,50道经典SQL题,真香~
晚上听说我们村子快解封了,居家办公的日子已不多,久久不能平息~~ 蹲坑之余,在网上找到了50道所谓经典SQL题,这不就是深夜必备小菜?我用脚叼起拖鞋,从冰箱拿出封印已久的半瓶可乐,打开数日未见 ...
- 常用经典SQL语句大全完整版--详解+实例 (存)
常用经典SQL语句大全完整版--详解+实例 转 傻豆儿的博客 http://blog.sina.com.cn/shadou2012 http://blog.sina.com.cn/s/blog_84 ...
- 用几何语言表示线段ab的中点c,做完这30道精选题,你的几何图形绝对满分!
原标题:做完这30道精选题,你的几何图形绝对满分! 1.某同学用剪刀沿直线将一片平整的银杏叶减掉一部分(如图),发现剩下的银杏叶的周长比原银杏叶的周长要小,能正确解释这一现象的数学知识是( ) A. ...
- 超经典SQL练习题,做完这些你的SQL就过关了
使用方法:我用的数据库是 Ms SQL Server 2008 ,练习时应当自己建数据,自己先思考,切勿急躁翻答案!否则效果减半,做完这些,恭喜你,你的 SQL 就算过关了. 测试表格 --1.学生表 ...
- 经典SQL题 1/25/50/100美分,多少种可能拼凑成2美元
如题,这类问题就是看思路,很多面试的时候都会遇到,思路到了,面试官也就默许了.也许不是很复杂,但确实实在. 1 With t1 as( 2 select 200 n union all 3 selec ...
- mysql经典sql语句大全_常用经典SQL语句大全完整版--详解+实例 (存)
下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL-数据定义语言(CREATE,ALTER,DROP,DECLARE) DML-数据操纵语言(SELECT,DELETE, ...
- 超经典动态规划题:最大子序和
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 ...
最新文章
- Javascript中的prototype
- Tomcat7.0安装配置
- Python零基础学习笔记(二十二)—— set
- VTK:Rendering之AmbientSpheres
- Android子线程真的不能更新UI么
- 使用SCVMM2012从hyper-v 2.0平台往hyper-v 3.0平台迁移VM虚拟机的报错(2)
- php 调取子栏目,Dedecms 如何调取某个栏目所在的顶级栏目及顶级下的子栏目
- 无人承运平台系统流程图
- java如何保证redis设置过期时间的原子性_分布式锁用 Redis 还是 Zookeeper
- Android第十四期 - 可扩展选项卡
- 网络协议:TCP可靠传输
- python如何爬取sci论文_通过爬虫确定SCI期刊的发表周期
- 为实现电动车长途旅行,特斯拉超级充电站将大幅升级
- NOSQL数据库习题
- 如何用Java写一个规范的http接口?
- 微软高性能缓存AppFabric(二)使用
- 量子保密通信技术基本原理
- C#创建Windows窗体应用程序实例8【通用对话框】
- 网络扫描 : nbtscan
- Pyqt5 遇到的超级无敌大坑!clicked.connect后面的connect出现下划线 计算机积极拒绝问题
热门文章
- 使用这个方法,让你的表格一目了然,你都明白吗
- android 360自动更新,Android应用自动更新功能的实现!!!
- poi 操作excel 自动换行
- Windows Server 2008 R2 标准版升级到企业版
- 招行U盾农行页面浏览器无法登录问题
- 【ASP.Net】视频上传和显示
- MacX DVD Ripper Pro for Mac用户指南:如何使用最新的版权保护措施翻录DVD?
- LG推出概念折叠三屏手机Triptych
- id 查找apple_如何使用 Apple ID 查找 iPhone?
- 陋室快报 | 近期好文分享:CLUE最新发布KgCLUE,开放域对话,Prompt-29211212