SQL练习题-3

员工表结构:

部门表结构:

部门员工表结构:

部门经理表结构:

薪资表结构:

1.查找所有员工自入职以来的薪水涨幅情况,给出员工编号emp_no以及其对应的薪水涨幅growth,并按照growth进行升序

分析:分别找出每个员工入职时的薪资即e.hire_date=s.from_date,每个员工当前的薪资即e.to_date=s.to_date,join关联找出每个emp_no对应的growth。

select r1.emp_no, (r1.salary-r2.salary) as growth from

(select emp_no,salary from salaries where to_date='9999-01-01')r1              #每位员工当前薪水

inner join

(select e.emp_no,salary from employees e inner join salaries s on e.emp_no=s.emp_no and e.hire_date=s.from_date)r2                  #每位员工入职时薪水

on r1.emp_no=r2.emp_no

order by growth;

2.统计各个部门的工资记录数,给出部门编码dept_no、部门名称dept_name以及次数sum

分析:多表联合查询,对部门编号分组,过滤表之间的关系。

select de.dept_no, d.dept_name, count(salary) sum from salaries s, dept_emp  de, departments d

where s.emp_no = de.emp_no and de.dept_no = d.dept_no

group by de.dept_no;

3.对所有员工的当前(to_date='9999-01-01')薪水按照salary进行按照1-N的排名,相同salary并列且按照emp_no升序排列

分析:考察自查询,限制条件to_date='9999-01-01',a.salary<=b.salary意思时在输出a.salary时,有多少b.salary大于等于a.salary。由于用了count()函数,需要对a.emp_no 分组group by。

select a.emp_no,a.salary,count(distinct b.salary) rank from salaries a,salaries b

where a.to_date='9999-01-01'

and b.to_date='9999-01-01'

and a.salary<=b.salary

group by a.emp_no

order by a.salary desc,a.emp_no  asc;

4.获取所有非manager员工当前的薪水情况,给出dept_no、emp_no以及salary

分析:首先找出非manager员工,连接salaries表找到对应的当前薪水,再连接dept_emp找到员工对应的部门

select de.dept_no, e.emp_no, s.salary from employees e

inner join salaries s on e.emp_no = s.emp_no and s.to_date = '9999-01-01'

inner join dept_emp de on de.emp_no = e.emp_no

where e.emp_no not in (select emp_no from dept_manager where to_date = '9999-01-01');


5.获取员工其当前的薪水比其manager当前薪水还高的相关信息,当前表示to_date='9999-01-01'

结果第一列给出员工的emp_no,

第二列给出其manager的manager_no,

第三列给出该员工当前的薪水emp_salary,

第四列给该员工对应的manager当前的薪水manager_salary

分析:分别找出各部门员工的薪水,各部门经理的薪水,限制条件为同一部门其员工薪水>经理薪水,按要求查询4列

select r1.emp_no emp_no, r2.emp_no manager_no, r1.salary emp_salary, r2.salary manager_salary from

(select de.emp_no,de.dept_no,s.salary from dept_emp de inner join salaries s on de.emp_no=s.emp_no and s.to_date='9999-01-01') r1,

(select dm.emp_no,dm.dept_no,s.salary from dept_manager dm inner join salaries s on dm.emp_no=s.emp_no and s.to_date='9999-01-01') r2

where r1.dept_no = r2.dept_no and r1.salary > r2.salary;

6.汇总各个部门当前员工的title类型的分配数目,结果给出部门编号dept_no、dept_name、其当前员工所有的title以及该类型title对应的数目count

select r.dept_no,d.dept_name,r.title,r.count from departments d inner join

(select de.dept_no,t.title,count(*) count from dept_emp de,titles t where de.emp_no=t.emp_no

and de.to_date='9999-01-01' and t.to_date='9999-01-01' group by de.dept_no,title)r

on d.dept_no=r.dept_no;

电影表结构:

分类表结构:

电影分类表结构:

7.查找描述信息中包括robot的电影对应的分类名称以及电影数目,而且还需要该分类对应电影数量>=5部

SELECT c.name AS name, COUNT(f.film_id) AS amount

FROM film AS f, film_category AS fc, category AS c,

(SELECT category_id FROM film_category GROUP BY category_id HAVING COUNT(category_id) >= 5) AS cc

WHERE f.description LIKE '%robot%'

AND f.film_id = fc.film_id

AND fc.category_id = c.category_id

AND c.category_id = cc.category_id;

8.使用join查询方式找出没有分类的电影id以及名称

select film_id,title from film where film_id not in

(select film_id from film_category fc inner join category c on fc.category_id=c.category_id);

9.使用子查询的方式找出属于Action分类的所有电影对应的title,description

select f.title,f.description from film f where f.film_id in

(select fc.film_id from film_category fc where fc.category_id in

(select c.category_id from category c where c.name='Action'));

10.获取select * from employees对应的执行计划

explain select * from employees;

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