SQL学习笔记06

Task 07 决胜秋招


Content

  • Section A(只写了练习一
  • Section B(没写
  • Section C(没写

Reference:
[1]GitHub - datawhalechina/wonderful-sql: Follow me,从 0 到 1 掌握 SQL,决胜秋招。
[2]笔试题 sql语句求出各部门工资最高的员工(leetcode)_纱王的博客-CSDN博客

缓慢更新中

Section A

练习一: 各部门工资最高的员工(难度:中等)
  1. 创建 Employee 表,包含所有员工信息,每个员工有其对应的 Id, salary 和 department Id
create database if not exists section_a;
use section_a;
drop table if exists emp;
create table emp(
    -> Id char(1) not null,
    -> Name varchar(100) not null,
    -> Salary int not null,
    -> Departmentid int,
    -> primary key(Id));
create table dept(
    -> Id char(1) not null,
    -> Name varchar(100) not null,
    -> primary key(Id));

select * from emp;
select * from dept;
1.1.png

(无语了简书插入图片怎么这么麻烦 用了下面三种方法都没办法调整图片大小
有没有人知道怎么改大小啊/(ㄒoㄒ)/~~.png
  1. 编写一个 SQL 查询,找出每个部门工资最高的员工。例如,根据上述给定的表格,Max 在 IT 部门有最高工资,Henry 在 Sales 部门有最高工资。


    1.2尝试.png

    第一次尝试发现输出的salary是最高的,但是名字对不上,筛选出了每个部门的第一个人,考虑应该先把两个表join起来再筛选

-- 法一(join)
/*先将两个表合起来*/
select dept.name as Department
  ,emp.name as Employee
  ,emp.salary as Salary
from dept inner join emp on dept.id=emp.departmentid
/*对合起来的表筛选*/
where 
  emp.salary in (
      select max(salary) 
        from emp  
        group by departmentid);  

-- 法二(关联子查询)
select d.name as Department
  ,e.name as Employee
  ,e.salary as Salary
from dept d,emp e
where e.departmentid=d.id
and 
  e.salary=(
      select max(salary) 
      from emp 
      where departmentid=d.id);

-- 法三(中间表-来源于CSDN)
select d.name Department 
,e.name Employee
,tb.salary Salary
from
  emp e, dept d,(select departmentId ,max(salary) salary from emp group by departmentId) tb
where e.salary=tb.salary 
and tb.departmentId=e.departmentId 
and tb.departmentId=d.Id

有几个容易错的地方:
1.where的时候不能用别名:
FROM WHERE GROUP BY HAVING SELECT ORDER BY
但是!表的别名必须用!不然会ERROR 1054 (42S22): Unknown column 'emp.departmentid' in 'where clause'
2.使用group by的时候,出现在select后面的字段 要么是是聚合函数中的,要么就是group by 中的字段。最后一步筛选最高薪水也可以写成\downarrow只要select里外一一对应就行

where
  (e.departmentid,e.salary) in (
    select departmentid,max(salary) 
    from emp 
    group by departmentid);
练习二: 换座位(难度:中等)
  1. 小美是一所中学的信息科技老师,她有一张 seat 座位表,平时用来储存学生名字和与他们相对应的座位 id。
    其中纵列的 id 是连续递增的
    小美想改变相邻俩学生的座位。
    你能不能帮她写一个 SQL query 来输出小美想要的结果呢?
    请创建如下所示 seat 表:
  +---------+---------+
- | id | student |
  +---------+---------+
- | 1 | Abbot |
5 | 2 | Doris |
- | 3 | Emerson |
- | 4 | Green |
- | 5 | Jeames |
- +---------+---------+

假如数据输入的是上表,则输出结果如下:(注意:如果学生人数是奇数,则不需要改变最后一个同学的座位。)

  +---------+---------+
- | id | student |
- +---------+---------+
- | 1 | Doris |
5 | 2 | Abbot |
- | 3 | Green |
- | 4 | Emerson |
- | 5 | Jeames |
- +---------+---------+
练习三: 分数排名(难度:中等)
  1. 编写一个 SQL 查询来实现分数排名。如果两个分数相同,则两个分数排名(Rank)相同。请注意,平分后的下一个名次应该是下一个连续的整数值。换句话说,名次之间不应该有“间隔”。
    创建以下 score 表:
  +----+-------+
- | Id | Score |
- +----+-------+
- | 1 | 3.50 |
5 | 2 | 3.65 |
- | 3 | 4.00 |
- | 4 | 3.85 |
- | 5 | 4.00 |
- | 6 | 3.65 |
10 +----+-------+

例如,根据上述给定的 Scores 表,你的查询应该返回(按分数从高到低排列):

 +-------+------+
- | Score | Rank |
- +-------+------+
- | 4.00 | 1 |
5 | 4.00 | 1 |
 | 3.85 | 2 |
- | 3.65 | 3 |
- | 3.65 | 3 |
- | 3.50 | 4 |
10 +-------+------+
练习四:连续出现的数字(难度:中等)
  1. 编写一个 SQL 查询,查找所有至少连续出现三次的数字
练习五:树节点(难度:中等)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容

  • Task 06 SQL高级处理 Content 窗口函数 GROUPING运算符 存储过程和参数 预处理声明PRE...
    yuiki_0829阅读 319评论 0 0
  • Task 05 集合运算 Content 表的加减法 连结(JOIN) 练习 Reference:[1]GitHu...
    yuiki_0829阅读 359评论 0 0
  • 1 安装MySQL 进入MySQL官网,登录 如何在Macbook上安装MySQL_百度经验 我之后改了个,怕忘记...
    乔大叶_803e阅读 496评论 0 0
  • Task 03 基础查询与排序 Content: 补充Task 01中的索引(index)内容 补充练习最后一问:...
    yuiki_0829阅读 236评论 0 0
  • 题目选自leetcode 上的题库 可能不一定都是最优解,答案仅供参考每道题后面都应相应的难度等级,如果没时间做的...
    顾子豪阅读 622评论 0 6