SQL面试用题

1. 查询每个月倒数第 2 天入职的员工的信息.

2. 查询出 last_name 为 'Chen' 的 manager 的信息.

3. 查询平均工资高于 8000 的部门 id 和它的平均工资.

4. 查询工资最低的员工信息: last_name, salary

5. 查询平均工资最低的部门信息

6. 查询平均工资最低的部门信息和该部门的平均工资

7. 查询平均工资最高的 job 信息

8. 查询平均工资高于公司平均工资的部门有哪些?

9. 查询出公司中所有 manager 的详细信息.

10. 各个部门中 最高工资中最低的那个部门的 最低工资是多少

11. 查询平均工资最高的部门的 manager 的详细信息: last_name, department_id, email, salary

12. 查询 1999 年来公司的人所有员工的最高工资的那个员工的信息.

13. 返回其它部门中比job_id‘IT_PROG’部门所有工资都低的员工的员工号、姓名、job_id 以及salary

 

************************answers*********************

1. 查询每个月倒数第 2 天入职的员工的信息.

select last_name, hire_date

from employees

where hire_date = last_day(hire_date) – 1

 

2. 查询出 last_name 为 'Chen' 的 manager 的信息.

1). 通过两条 sql 查询:

  

select manager_id

from employees

where lower(last_name) = 'chen' --返回的结果为 108

 

select *

from employees

where employee_id = 108

 

2). 通过一条 sql 查询(自连接):

 

select m.*

from employees e, employees m

where e.manager_id = m.employee_id and e.last_name = 'Chen'

 

3). 通过一条 sql 查询(子查询):

 

select *

from employees

where employee_id = (

                      select manager_id

                      from employees

                      where last_name = 'Chen'

                    )

3. 查询平均工资高于 8000 的部门 id 和它的平均工资.

SELECT department_id, avg(salary)

FROM employees e

GROUP BY department_id

HAVING avg(salary) > 8000

 

 

4. 查询工资最低的员工信息: last_name, salary

SELECT last_name, salary

FROM employees

WHERE salary = (

SELECT min(salary)

FROM employees

)

 

 

本教程由尚硅谷教育大数据研究院出品,如需转载请注明来源。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值