牛客网SQL刷题——更新版

1.查找最晚入职员工的所有信息

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`));

牛客网SQL刷题——更新版_第1张图片

 思路:1.找到入职hire_date最晚的日期2.找到最晚日期对应的所有职工

select * from employees where hire_date=(select max(hire_date) from employees)

2.查找入职员工时间排名倒数第三的员工所有信息

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`));

牛客网SQL刷题——更新版_第2张图片

思路:1.对入职日期按降序排列

2.查询结果限制从第2个元素开始输出(编号从0开始),输出一个元素

select *from employees order by hire_date desc limit 2,1

3.查找各个部门当前(to_date='9999-01-01')领导当前薪水详情以及其对应部门编号dept_no

CREATE TABLE `dept_manager` (
`dept_no` char(4) NOT NULL,
`emp_no` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_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`));

牛客网SQL刷题——更新版_第3张图片

select salaries.*, dept_manager.dept_no from salaries ,  dept_manager 
where salaries.to_date='9999-01-01'
and dept_manager.to_date='9999-01-01'
and salaries.emp_no=dept_manager.emp_no;

 思路:查询的内容在两张表里面,所以要用到多表连接,这里使用内连接即可,因为两表均有emp_no字段,所以where连接判断时取两表相等时判断。此外还要考虑题目要求

4.查找所有已经分配部门的员工的last_name和first_name以及dept_no

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`));
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`));

牛客网SQL刷题——更新版_第4张图片

select employees.last_name,employees.first_name,dept_emp.dept_no
from  employees,dept_emp
where employees.emp_no=dept_emp.emp_no

5.查找所有员工的last_name和first_name以及对应部门编号dept_no,也包括暂时没有分配具体部门的员工

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`));
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`));

牛客网SQL刷题——更新版_第5张图片

select e.last_name,e.first_name,d.dept_no
from employees as e left join dept_emp  as d
on d.emp_no=e.emp_no

 考察“左外连接”,在查询时,左边的表全部保留,如果左边表没有右边表中的元素,则为空

你可能感兴趣的:(SQL)