SQL练习题-2

员工表结构:


部门表结构:

部门员工表结构:

部门经理表结构:

薪资表结构:

1.获取所有员工当前的manager,如果当前的manager是自己的话结果不显示,当前表示to_date='9999-01-01'。结果第一列给出当前员工的emp_no,第二列给出其manager对应的manager_no。

分析:join连接两表,限制条件dept_no要相等,而两表emp_no不相等,两表to_date='9999-01-01'

select de.emp_no, dm.emp_no as manager_no from dept_emp as  de inner join dept_manager dm 

on de.dept_no=dm.dept_no 

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

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

 and de.emp_no<>dm.emp_no;

2.获取所有部门中当前员工薪水最高的相关信息,给出dept_no, emp_no以及其对应的salary

分析:对部门group by分组,max()函数找到salary最大值,限定条件to_date='9999-01-01'

select d.dept_no, s.emp_no,max(salary) from dept_emp d, salaries s 

where d.emp_no=s.emp_no 

and d.to_date=s.to_date 

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

group by d.dept_no;

3.从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。

titles表结构:

分析:group by分组,count() 函数记录行数,having过滤条件。

select title,count(*) t from titles group by title having count(*)>=2;

4.从titles表获取按照title进行分组,每组个数大于等于2,给出title以及对应的数目t。注意对于重复的emp_no进行忽略。

分析:要忽略重复的emp_no,先对title分组,然后count(distinct emp_no)可以统计同一title下不同员工的个数

select title,count(distinct emp_no) t from titles group by title having t>=2;

5.查找employees表所有emp_no为奇数,且last_name不为Mary的员工信息,并按照hire_date逆序排列

分析: 使用where过滤条件, 奇数判断可用emp_no%2=1,

select * from employees where emp%2=1 and last_name<>Mary order by hire_date desc;

6.统计出当前各个title类型对应的员工当前(to_date='9999-01-01')薪水对应的平均工资。结果给出title以及平均工资avg。

分析:联合查询,限定条件t.emp_no=s.emp_no,限制当前(9999-01-01)条件,对title进行分组,avg()函数求平均值

select t.title, avg(salary) avg from titles t,salaries s 

where t.emp_no=s.emp_no 

and t.to_date=s.to_date 

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

group by t.title; 

7.获取当前(to_date='9999-01-01')薪水第二多的员工的emp_no以及其对应的薪水salary

分析:要考虑到多人同一薪资的情况,对薪水分组降序排序,用limit m,n 查询第二条记录

select emp_no,salary from salaries where to_date='9999-01-01' and salary=(select salary from salaries group by salary order by salary desc limit1,1);

8.查找当前薪水(to_date='9999-01-01')排名第二多的员工编号emp_no、薪水salary、last_name以及first_name

分析:max()函数找到第二高的薪水,连接两表,限制条件为e.emp_no=s.emp_no,to_date='9999-01-01'

select e.emp_no,s.salary,e.last_name,e.first_name from employees e join salaries s 

on e.emp_no=s.emp_no and s.salary=

(select max(salary) from salaries  where salary < 

(select max(salary) from salaries where to_date='9999-01-01'01') and to_date='9999-01-01') 

and e.to_date='9999-01-01';

9.查找所有员工的last_name和first_name以及对应的dept_name,也包括暂时没有分配部门的员工

部门表结构:

分析:“员工表”、“部门员工表”和“部门表”,用left join连接employees和dept_emp两表,再用left join连接departments表,最后得到想要的结果。

select e.last_name,e.first_name,d.dept_name from employees e

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

left join departments d on de.dept_no = d.dept_no;

10.查找员工编号emp_no为10001其自入职以来的薪水salary涨幅值growth

分析:分别找出该员工入职时的薪水及最后一次的薪水,然后做差,别名为growth

select (

(select salary from salaries where emp_no='10001' order by to_date desc limit 1)-

(select salary from salaries where emp_no='10001' order by to_date asc limit 1)

) as growth;

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