员工信息表
CREATE TABLE
employees
(
emp_no
int(11) NOT NULL, – ‘员工编号’
birth_date
date NOT NULL,
first_name
varchar(14) NOT NULL,
last_name
varchar(16) NOT NULL,
gender
char(1) NOT NULL,
hire_date
date NOT NULL,
PRIMARY KEY (emp_no
));
工资表
CREATE TABLE
salaries
(
emp_no
int(11) NOT NULL, – ‘员工编号’,
salary
int(11) NOT NULL,
from_date
date NOT NULL,
to_date
date NOT NULL,
PRIMARY KEY (emp_no
,from_date
));
部门表1
CREATE TABLE
dept_manager
(
dept_no
char(4) NOT NULL, – ‘部门编号’
emp_no
int(11) NOT NULL, – ‘员工编号’
to_date
date NOT NULL,
PRIMARY KEY (emp_no
,dept_no
));
部门表2
CREATE TABLE
dept_emp
(
emp_no
int(11) NOT NULL,
dept_no
char(4) NOT NULL,
from_date
date NOT NULL,
to_date
date NOT NULL,
PRIMARY KEY (emp_no
,dept_no
));
1. 查找最晚入职员工的所有信息,为了减轻入门难度,目前所有的数据里员工入职的日期都不是同一天
select * from employees order by hire_date desc limit 1;
2. 查找入职员工时间排名倒数第三的员工所有信息,为了减轻入门难度,目前所有的数据里员工入职的日期都不是同一天
select * from employees order by hire_date desc limit 1 offset 2;
3. 查找各个部门当前(dept_manager.to_date=‘9999-01-01’)领导当前(salaries.to_date=‘9999-01-01’)薪水详情以及其对应部门编号dept_no
(注:请以salaries表为主表进行查询,输出结果以salaries.emp_no升序排序,并且请注意输出结果里面dept_no列是最后一列)
select s.*, d.dept_no
from salaries s join dept_manager d
on s.emp_no = d.emp_no
where s.to_date='9999-01-01' and d.to_date='9999-01-01';
4. 查找所有已经分配部门的员工的last_name和first_name以及dept_no(请注意输出描述里各个列的前后顺序)
select e.last_name,e.first_name,d.dept_no
from dept_emp d join employees e
on d.emp_no = e.emp_no;
5. 查找所有员工的last_name和first_name以及对应部门编号dept_no,也包括暂时没有分配具体部门的员工(请注意输出描述里各个列的前后顺序)
select e.last_name, e.first_name, d.dept_no
from employees e left join dept_emp d
on e.emp_no=d.emp_no;
6. 查找所有员工入职时候的薪水情况,给出emp_no以及salary, 并按照emp_no进行逆序(请注意,一个员工可能有多次涨薪的情况)
select e.emp_no,s.salary
from employees e ,salaries s
where e.emp_no = s.emp_no and e.hire_date = s.from_date
order by e.emp_no desc;
7. 查找薪水变动超过15次的员工号emp_no以及其对应的变动次数t
select emp_no ,count(distinct salary) t
from salaries
group by emp_no having t > 15;
8. 找出所有员工当前(to_date=‘9999-01-01’)具体的薪水salary情况,对于相同的薪水只显示一次,并按照逆序显示
select distinct salary from salaries
where to_date = '9999-01-01'
order by salary desc;
9. 获取所有部门当前(dept_manager.to_date=‘9999-01-01’)manager的当前(salaries.to_date=‘9999-01-01’)薪水情况,给出dept_no, emp_no以及salary(请注意,同一个人可能有多条薪水情况记录)
select d.dept_no,d.emp_no,s.salary
from dept_manager d, salaries s
where d.emp_no = s.emp_no
and d.to_date = '9999-01-01'
and s.to_date = '9999-01-01';
10. 获取所有非manager的员工emp_no
select e.emp_no
from employees e left join dept_manager d
on e.emp_no = d.emp_no
where dept_no is null;