MySQL多表连接查询

news/2024/11/16 20:50:36/

目录

表结构

创建表

表数据插入

查询需求

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


命令:create table emp (sid int ,name varchar(11),age int,worktime_start date,incoming int,dept2 int);


表内容如下: 

 


表数据插入

命令:

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

查询需求

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='销售';

 

 

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='财务';

 

 

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;

 

 

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

 

 

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='销售');

 

 

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;

 

 

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;

 

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技术';

 

 

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='财务';

 

 

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;

 

 

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

 

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;

 

 

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;

 

 

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

 

 

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='李四';

 

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;

 

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

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

 

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='张三';

 

 


http://www.ppmy.cn/news/1022648.html

相关文章

关于@JSONField的使用

1.此注解来自jar包com.alibaba.fastjson 今天分享一个有意思的事情。这个注解作用与类的属性上&#xff0c;如下&#xff1a; ApiModelProperty(value"开始时间,格式:yyyy-MM-dd",required true) JSONField(name"start_date",ordinal 1) private String…

OpenText 企业安全 调查 产品简介

关于OpenText OpenText是一家信息软件公司&#xff0c;使企业能够通过市场领先的信息管理解决方案&#xff08;内部或云中&#xff09;获得洞察力。 全球面临的数字风险 市场合力驱动的信息管理 处于风暴中心的信息 →安全漏洞和数据保护 • 防止威胁并将破坏影响降至最低 …

百度刘林:渗透深层企业经营 AIGC将为千行百业带来变革机会

近年来人工智能领域迅猛发展&#xff0c;随着AIGC概念的走红&#xff0c;生成式大模型技术领域硕果累累&#xff0c;尤其在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;生成式AI的大语言模型实现了理解人类意图的技术跨越。 值此行业变革的关键节点&#xff0c;深…

Redis布隆过滤器的原理和应用场景,解决缓存穿透

目录 一、redis 二、布隆过滤器 三、缓存穿透问题 四、布隆过滤器解决缓存穿透 一、redis Redis&#xff08;Remote Dictionary Server&#xff09;是一种开源的内存数据存储系统&#xff0c;也是一个使用键值对&#xff08;Key-Value&#xff09;方式的高性能数据库。Red…

混合云环境中 Kubernetes 可观测性的 6 个有效策略...

2023 年&#xff0c;原生云应用程序和平台将快速增长。组织不断努力最大限度地发挥其应用程序的潜力&#xff0c;确保无缝的用户体验并推动业务增长。 混合云环境的兴起以及 Kubernetes 等容器化技术的采用彻底改变了现代应用程序的开发、部署和扩展方式。 在这个数字领域&am…

Android上的基于协程的存储框架

在Android上&#xff0c;经常会需要持久化本地数据&#xff0c;比如我们需要缓存用户的配置信息、用户的数据、缓存数据、离线缓存数据等等。我们通常使用的工具为SharePreference、MMKV、DataStore、Room、文件等等。通过使用现有的存储框架&#xff0c;结合协程&#xff0c;我…

内卷下的网络工程师,如何破局?

中午好&#xff0c;我的网工朋友 说起IT行业&#xff0c;大多数人都会想起程序员或者是开发这样的主流岗&#xff0c;但如果说起IT行业到底谁才是最底层的岗位&#xff0c;每个人都想说一嘴&#xff1a; “那必须是我&#xff01;” 客观来看&#xff0c;到底哪个岗位才是IT的…

虚拟展览馆有哪些优势?如何打造自己的虚拟展览馆

引言&#xff1a; 随着科技的不断创新与发展&#xff0c;虚拟展览馆作为一种全新的文化体验方式&#xff0c;正逐渐引起人们的关注。虚拟展览馆以其便捷、创新、可定制的特点&#xff0c;为参观者提供了前所未有的沉浸式体验。 一&#xff0e;什么是虚拟展览馆&#xff1f; 虚…