MySQL多表连接查询

目录

表结构

创建表

表数据插入

查询需求

1.找出销售部门中年纪最大的员工的姓名

2.求财务部门最低工资的员工姓名

3.列出每个部门收入总和高于9000的部门名称

4.求工资在7500到8500元之间,年龄最大的人的姓名及部门

5.找出销售部门收入最低的员工入职时间

6.财务部门收入超过2000元的员工姓名

7.列出每个部门的平均收入及部门名称

8.IT技术部入职员工的员工号

9.财务部门的收入总和;

10.先按部门号大小排序,再依据入职时间由早到晚排序员工信息表

11.找出哪个部门还没有员工入职;

12.列出部门员工收入大于7000的部门编号,部门名称;

13.列出每一个部门的员工总收入及部门名称;

14.列出每一个部门中年纪最大的员工姓名,部门名称;

15.求李四的收入及部门名称

16.列出每个部门中收入最高的员工姓名,部门名称,收入,并按照收入降序

17.列出部门员工数大于1个的部门名称

18.查找张三所在的部门名称


表结构

        员工表emp

        部门表dept

创建表

命令:create table dept (dept1 int ,dept_name varchar(11));

MySQL多表连接查询_第1张图片
命令:create table emp (sid int ,name varchar(11),age int,worktime_start date,incoming int,dept2 int);

MySQL多表连接查询_第2张图片


表内容如下: 

MySQL多表连接查询_第3张图片 


表数据插入

命令:

insert into dept values
    (101,'财务'),
    (102,'销售'),
    (103,'IT技术'),
    (104,'行政');

命令:

insert into emp values
    (1789,'张三',35,'1980/1/1',4000,101),
    (1674,'李四',32,'1983/4/1',3500,101),
    (1776,'王五',24,'1990/7/1',2000,101),
    (1568,'赵六',57,'1970/10/11',7500,102),
    (1564,'荣七',64,'1963/10/11',8500,102),
    (1879,'牛八',55,'1971/10/20',7300,103);

MySQL多表连接查询_第4张图片

查询需求

1.找出销售部门中年纪最大的员工的姓名

命令:

方式一:

select emp.name from emp inner join dept on emp.dept2=dept.dept1 where dept.dept_name='销售' order by emp.age desc limit 1;

方式二:

select max(age) from dept,emp where dept.dept1=emp.dept2 and dept_name='销售';
select name from dept,emp where  dept.dept1=emp.dept2 and age=(select max(age) from dept,emp where dept.dept1=emp.dept2 and dept_name='销售') and dept_name='销售';

MySQL多表连接查询_第5张图片 

 

2.求财务部门最低工资的员工姓名

命令:

方式一:

select emp.name from emp inner join dept on emp.dept2=dept.dept1 where dept.dept_name='财务' order by emp.incoming limit 1;

方式二:

select min(incoming) from dept,emp where dept.dept1=emp.dept2 and dept_name='财务';
select name from dept,emp where dept.dept1=emp.dept2 and  incoming=(select min(incoming) from dept,emp where dept.dept1=emp.dept2 and dept_name='财务') and dept_name='财务';

MySQL多表连接查询_第6张图片 

 

3.列出每个部门收入总和高于9000的部门名称

命令:

select dept.dept_name from emp left join dept on emp.dept2=dept.dept1 group by dept.dept_name having sum(incoming)>9000;

select dept_name from dept,emp where dept.dept1=emp.dept2 group by dept_name having sum(incoming)>9000;

MySQL多表连接查询_第7张图片

 

 

4.求工资在7500到8500元之间,年龄最大的人的姓名及部门

命令: 

方式一:

            select emp.name,dept.dept_name
            from dept inner join emp
            on emp.dept2=dept.dept1
            where emp.age=(select max(emp.age) from emp where emp.incoming between 7500 and 8500);

方式二:

select max(age) from emp;

select name,dept_name from dept,emp where dept.dept1=emp.dept2 and incoming between 7500 and 8500 and age=(select max(age) from emp);

select name,dept_name from dept,emp where dept.dept1=emp.dept2 and incoming >= 7500 and incoming<=8500 and age=(select max(age) from emp);

MySQL多表连接查询_第8张图片

MySQL多表连接查询_第9张图片 

 

5.找出销售部门收入最低的员工入职时间

命令:

方式一:

select emp.worktime_start from emp where emp.incoming = (select min(emp.incoming) from emp inner join dept on emp.dept2=dept.dept1 where dept.dept_name='销售');

方式二:

select min(incoming) from dept,emp where dept.dept1=emp.dept2 and dept_name='销售';

select worktime_start from emp where incoming=(select min(incoming) from dept,emp where dept.dept1=emp.dept2 and dept_name='销售');

MySQL多表连接查询_第10张图片

MySQL多表连接查询_第11张图片 

 

6.财务部门收入超过2000元的员工姓名

命令:

select emp.name,emp.incoming from emp inner join dept on emp.dept2=dept.dept1 and emp.incoming>2000 and dept.dept_name='财务';

select name from dept,emp where dept.dept1=emp.dept2 and dept_name='财务' and incoming>2000;

MySQL多表连接查询_第12张图片

MySQL多表连接查询_第13张图片 

 

7.列出每个部门的平均收入及部门名称

命令:

select dept.dept_name, avg(emp.incoming) from dept inner join emp on emp.dept2=dept.dept1 group by dept.dept_name;

select t.dept_name,avg(incoming) from (select * from dept,emp where dept.dept1=emp.dept2) t group by t.dept_name;

select dept_name,avg(incoming) from dept,emp where dept.dept1=emp.dept2 group by dept_name;

MySQL多表连接查询_第14张图片

 

8.IT技术部入职员工的员工号

命令:

select emp.sid from emp inner join dept on emp.dept2=dept.dept1 where dept.dept_name='IT技术';

select sid from dept,emp where dept.dept1=emp.dept2 and dept_name='IT技术';

MySQL多表连接查询_第15张图片 

 

9.财务部门的收入总和;

命令:

select sum(emp.incoming) as 收入总和 from emp inner join dept on emp.dept2=dept.dept1 where dept.dept_name='财务';

select sum(incoming) from dept,emp where dept.dept1=emp.dept2 and dept_name='财务';

MySQL多表连接查询_第16张图片

 MySQL多表连接查询_第17张图片

 

10.先按部门号大小排序,再依据入职时间由早到晚排序员工信息表

命令: 

方式一:select *from emp right join dept on emp.dept2=dept.dept1 order by dept.dept1 asc,worktime_start asc;

方式二:select * from emp order by dept2 desc,worktime_start asc;

MySQL多表连接查询_第18张图片

 MySQL多表连接查询_第19张图片

 

11.找出哪个部门还没有员工入职;

命令:

方式一:select dept.dept_name from dept left join emp on emp.dept2=dept.dept1 where dept.dept1 not in (select emp.dept2 from emp);

方式二:select dept_name from dept LEFT JOIN emp on dept.dept1=emp.dept2 where sid is null;

方式三:select dept_name from dept where dept1 not in (select dept2 from emp);

MySQL多表连接查询_第20张图片

 

12.列出部门员工收入大于7000的部门编号,部门名称;

命令:

select distinct dept.dept1,dept.dept_name from dept inner join emp on emp.dept2=dept.dept1 where emp.incoming>7000;

select distinct dept1,dept_name from dept,emp where dept.dept1=emp.dept2 and incoming>7000;

MySQL多表连接查询_第21张图片

MySQL多表连接查询_第22张图片 

 

13.列出每一个部门的员工总收入及部门名称;

命令:

select dept.dept_name,sum(emp.incoming) as 员工总收入 from dept inner join emp on emp.dept2=dept.dept1 group by dept.dept_name;

select sum(incoming),dept_name from dept,emp where dept.dept1=emp.dept2 group by dept_name;

MySQL多表连接查询_第23张图片

 MySQL多表连接查询_第24张图片

 

14.列出每一个部门中年纪最大的员工姓名,部门名称;

命令:

方式一:

select emp.name,dept.dept_name from emp inner join dept on emp.dept2=dept.dept1
           where emp.age in (select max(emp.age) from dept inner join emp on                     emp.dept2=dept.dept1 group by dept.dept_name);

 方式二:

select name,dept_name from dept,emp where dept.dept1=emp.dept2 and age in (select max(age) from emp group by dept2);MySQL多表连接查询_第25张图片

MySQL多表连接查询_第26张图片 

 

15.求李四的收入及部门名称

 命令: 

select emp.name,emp.incoming,dept.dept_name from emp inner join dept on emp.dept2=dept.dept1 where emp.name='李四' ;

select incoming,dept_name from dept,emp where dept.dept1=emp.dept2 and name='李四';

MySQL多表连接查询_第27张图片

MySQL多表连接查询_第28张图片

 

16.列出每个部门中收入最高的员工姓名,部门名称,收入,并按照收入降序

命令:select name,dept_name,incoming from dept,emp where dept.dept1=emp.dept2 and incoming in (select max(incoming) from emp group by dept2) order by incoming desc;

MySQL多表连接查询_第29张图片

 

17.列出部门员工数大于1个的部门名称

命令:select dept_name from dept,emp where emp.dept2=dept.dept1 group by dept_name having count(*)>1;

MySQL多表连接查询_第30张图片

 

18.查找张三所在的部门名称

命令: 

方法一:

select dept_name from dept inner join emp on emp.dept2=dept.dept1 where emp.name='张三';

方法二:

select dept_name from dept,emp where dept.dept1=emp.dept2 and name='张三';

MySQL多表连接查询_第31张图片

MySQL多表连接查询_第32张图片 

 

你可能感兴趣的:(DateBase,mysql,数据库,windows,SELECT)