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


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

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/67913.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

国内10大云服务器厂商,你用过几个?

国内排名前10的云服务器厂商如下&#xff1a; 1、阿里云。阿里云是国内最大的云计算服务商之一&#xff0c;其云服务器产品具有高可用性、高扩展性和高安全性等优势&#xff0c;深受广大用户的青睐。 2、腾讯云。腾讯云是国内领先的云计算服务商之一&#xff0c;其云服务器产品…

修改k8s pod的挂载目录

1、找到挂载的服务 kubectl get service2、编辑pod的环境配置 kubectl edit deployment vendor-basic-bill-executor3、找到需要挂载的目录

01-向量究竟是什么?

文章作者&#xff1a;里海 来源网站&#xff1a;https://blog.csdn.net/WangPaiFeiXingYuan 向量究竟是什么 引入一些数作为坐标是一种鲁莽的行为 ——赫尔曼外尔 The introduction of numbers as coordinates is an act of violence - Hermann Weyl 向量的定义 向量&#xff0…

编译iOS系统可用的FFmpeg

在进行编译之前&#xff0c;需要做一些准备工作安装必备文件&#xff1a; 1 安装 gas-preprocessor FFmpeg-iOS-build-script 自动编译脚本需要使用到 gas-preprocessor . 执行 sudo git clone https://github.com/bigsen/gas-preprocessor.git /usr/local/bin/gas sudo c…

idea更改背景-给idea设置个性化背景

一&#xff0c;具体操作 按两次键盘Shift,打开快速查找/搜索功能 输入setb 选择Set Backgrounf Image 选择本地图片 二&#xff0c;推荐图片网站 Awesome Wallpapers - wallhaven.cc 该网站拥有大量免费高清图片可以白嫖

jupyter lab环境配置

1.jupyterlab 使用虚拟环境 conda install ipykernelpython -m ipykernel install --user --name tf --display-name "tf" #例&#xff1a;环境名称tf2. jupyter lab kernel管理 show kernel list jupyter kernelspec listremove kernel jupyter kernelspec re…

带你彻底了解什么是API接口?

作为一名资深程序员&#xff0c;我知道很多人对API接口这个名词可能还不太了解。今天我要给大家分享一些关于API接口的知识&#xff0c;让你们彻底了解它的概念和作用。一起来看看吧&#xff01; 首先&#xff0c;我们先来解释一下API的全称─Application Programming Interfac…

腾讯云轻量服务器和云服务器的CPU处理器有差别吗?

腾讯云轻量应用服务器和CVM云服务器的CPU处理器性能有差别吗&#xff1f;创建轻量应用服务器时不支持指定底层物理服务器的CPU型号&#xff0c;腾讯云将随机分配满足套餐规格的物理CPU型号&#xff0c;通常优先选择较新代次的CPU型号。而云服务器CVM的CPU处理器型号、主频都是有…

函数的递归

1、什么是递归&#xff1f; 程序调用自身的编程技巧称为递归。 递归作为一种算法在程序设计语言中广泛应用。一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法&#xff0c;它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解&#x…

计算机网络实验4:HTTP、DNS协议分析

文章目录 1. 主要教学内容2. HTTP协议3. HTTP分析实验【实验目的】【实验原理】【实验内容】【实验思考】 4. HTTP分析实验可能遇到的问题4.1 捕捉不到http报文4.2 百度是使用HTTPS协议进行传输4.3 Wireshark获得数据太多如何筛选4.4 http报文字段含义不清楚General&#xff08…

Linux系统之使用cmatrix实现数字雨效果

Linux系统之使用cmatrix实现数字雨效果 一、cmatrix介绍二、本地环境介绍2.1 本地环境规划2.2 本次实践介绍 三、环境准备工作3.1 安装开发环境3.2 安装基本软件3.3 安装 ImageMagick等工具 四、安装aalib工具4.1 新建目录4.2 下载aalib安装包4.3 解压软件包4.4 编译安装aalib …

Visdom安装避坑

VIsdom&#xff0c;与tensorboard作用类似 通过以下命令安装Visdom&#xff0c; pip install visdom 启动visdom服务 python -m visdom.server 运行一直卡在Downloading scripts, this may take a little while&#xff0c;某些资源因为网络问题难以下载&#xff0c;导致一…

C语言创建目录(文件夹)之mkdir

一、mkdir 说明&#xff1a;创建目录。 头文件库&#xff1a; #include <sys/stat.h> #include <sys/types.h>函数原型&#xff1a; int mkdir(const char *pathname, mode_t mode);mode方式&#xff1a;可多个权限相或&#xff0c;如0755表示S_IRWXU | S_IRGRP…

C++,文本文件,读取文件

代码演示&#xff1a; #include<iostream> using namespace std; #include<string> #include<fstream>void test() {//1、包含头文件//2、创建流对象ifstream ifs;//3、打开文件并判断文件是否成功ifs.open("test.txt", ios::in);if (!ifs.is_ope…

halo --- 上传图片服务器错误

文章目录 问题定位过程1、查看日志 报错的是数据库操作异常2、再次上传一张小一点的图片3、检查nginx的配置文件 原因解决 问题 上传图片时&#xff0c;报错服务器错误&#xff08;包括上传附件、博客文章插入图片、上传相册&#xff09; 定位过程 1、查看日志 报错的是数据库…

css冒号对齐

实现后的样式效果 实现方式 html&#xff1a; <el-col v-if"item.showInSingle ! false" :span"6" style"padding: 4px 0"><label>{{ item.label }}&#xff1a;</label><span v-if"singleData[item.prop] ! 0 &…

【LeetCode】买卖股票的最佳时机含冷冻期

买卖股票的最佳时机含冷冻期 题目描述算法分析程序设计 链接: 买卖股票的最佳时机含冷冻期 题目描述 算法分析 程序设计 class Solution { public:int maxProfit(vector<int>& prices) {int n prices.size();//天数vector<vector<int>> dp(n,vector&l…

当我准备出门时,发现了......我可以用Python实现12306自动买票

前言 不知道大家有没有之前碰到这样的情况&#xff0c;打算去某一个地方当你规划好了时间准备去买票的时候&#xff0c;你想要的那一列往往没有你想要的票了&#xff0c;尤其是国庆七天假和春节半月假&#xff0c;有时候甚至买不到规定计划时间内的票&#xff0c;真的是太烦躁…

【JVM】 垃圾回收篇——自问自答(1)

Q什么是垃圾&#xff1a; 运行程序中&#xff0c;没用任何指针指向的对象。 Q为什么需要垃圾回收&#xff1f; 内存只分配&#xff0c;不整理回收&#xff0c;迟早会被消耗完。 内存碎片的整理&#xff0c;为新对象腾出空间 没有GC程序无法正常进行。 Q 哪些区域有GC&#…

爬虫013_函数的定义_调用_参数_返回值_局部变量_全局变量---python工作笔记032

然后再来看函数,可以避免重复代码 可以看到定义函数以及调用函数