Day35
今天有事,下午没学习,只有晚上学了一个半小时,最近学习的心态不太好,要改正,明天要学够7个小时,加油OVO
/*测 试
1. 查询工资最低的员工信息: last_name, salary
2. 查询平均工资最低的部门信息
3. 查询平均工资最低的部门信息和该部门的平均工资
4. 查询平均工资最高的 job 信息
5. 查询平均工资高于公司平均工资的部门有哪些?
6. 查询出公司中所有 manager 的详细信息.
7. 各个部门中 最高工资中最低的那个部门的 最低工资是多少
8. 查询平均工资最高的部门的 manager 的详细信息: last_name, department_id, email,
salary
*/
#1. 查询工资最低的员工信息: last_name, salary
SELECT last_name,salary
FROM employees
WHERE salary=(
SELECT MIN(salary)
FROM employees
)
#2. 查询平均工资最低的部门信息
SELECT d.*
FROM departments d
WHERE d.department_id IN(
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary)=(
SELECT MIN(ag)
FROM (
SELECT AVG(salary) ag,department_id
FROM employees
GROUP BY department_id
) ag_dep));
#3. 查询平均工资最低的部门信息和该部门的平均工资
#4. 查询平均工资最高的 job 信息
SELECT j.*
FROM jobs j
WHERE job_id IN(
SELECT job_id
FROM employees
GROUP BY job_id
HAVING AVG(salary)=(
SELECT MAX(ag)
FROM (
SELECT AVG(salary) ag,job_id
FROM employees
GROUP BY job_id
) ag_emp))
#5. 查询平均工资高于公司平均工资的部门有哪些?
SELECT department_id,AVG(salary) 平均工资
FROM employees
WHERE department_id IN(
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary)>(
SELECT AVG(salary)
FROM employees
))
GROUP BY department_id
#6. 查询出公司中所有 manager 的详细信息.
SELECT last_name,manager_id
FROM employees
WHERE manager_id=(
SELECT manager_id
FROM employees
GROUP BY manager_id
)
GROUP BY manager_id
#分页查询
/*应用场景:当要显示的数据,一页显示不全,需要分页提交sql请求
语法:
select 查询列表
from 表
【join type join 表2
