Mysql数据库两表连接进行各种操作

news2024/9/23 15:27:59

一,创建两个表emp和dept,并给它们插入数据

1.创建表emp

create table dept (dept1 int ,dept_name varchar(11)) charset=utf8;

2.创建表dept
 create table emp (sid int ,name varchar(11),age int,worktime_start date,incoming int,dept2 int) charset=utf8;
3.为dept表输入数据

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

4.为emp表输入数据

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),
    (1668, '钱九', 64, '1963/5/4', 8000, 102),
    (1724, '武十', 22, '2023/5/8', 1500, 103),
    (1770, '孙二', 65, '1986/8/12', 9500, 101),
    (18400, '苟一', 65, '1986/8/12', 1500, 101);

二.连接查询操作

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

select e.name from emp e
    join dept d
    on e.dept2=d.dept1
    order by e.age desc
    limit 1;

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

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

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

 SELECT d.dept_name, SUM(e.incoming) AS total_income
    FROM dept d
    JOIN emp e ON d.dept1 = e.dept2
    GROUP BY d.dept_name
    HAVING total_income > 9000;

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

SELECT e.name, d.dept_name FROM emp e
    JOIN dept d ON e.dept2 = d.dept1
    WHERE e.incoming BETWEEN 7500 AND 8500
    ORDER BY e.age DESC
    LIMIT 1;

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

 SELECT e.worktime_start
    FROM emp e
    JOIN dept d ON e.dept2 = d.dept1
    WHERE d.dept_name = '销售'
    ORDER BY e.incoming ASC
    LIMIT 1;

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

SELECT e.name
    FROM emp e
    JOIN dept d ON e.dept2 = d.dept1
    WHERE d.dept_name = '财务' AND e.incoming > 2000;

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

 SELECT d.dept_name, AVG(e.incoming) AS average_income
    FROM dept d
    JOIN emp e ON d.dept1 = e.dept2
    GROUP BY d.dept_name;

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

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

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

select  sum(e.incoming)
    from emp e
    join dept d on e.dept2=d.dept1
    where d.dept_name='财务';

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

SELECT d.dept_name FROM dept d LEFT JOIN emp e ON d.dept1 = e.dept2 WHERE e.sid IS NULL;

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

select d.dept1,d.dept_name from dept d
    -> join emp e on d.dept1=e.dept2
    -> where e.incoming>7000;

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

SELECT d.dept_name, SUM(e.incoming) AS total_income

FROM dept d

JOIN emp e ON d.dept1 = e.dept2

GROUP BY d.dept_name;

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

SELECT e.name, d.dept_name FROM emp e INNER JOIN dept d ON e.dept2 = d.dept1 WHERE (e.dept2, e.age) IN (SELECT dept2, MAX(age) FROM emp GROUP BY dept2);
 

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

SELECT e.incoming, d.dept_name FROM emp e INNER JOIN dept d ON e.dept2 = d.dept1 WHERE e.name = '李四';
 

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

SELECT e.name, d.dept_name, e.incoming FROM emp e INNER JOIN dept d ON e.dept2 = d.dept1 WHERE (e.dept2, e.incoming) IN (SELECT dept2, MAX(incoming) FROM emp GROUP BY dept2) ORDER BY e.incoming DESC;



    

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电脑清理c盘内存空间怎么清理免费 怎么清理c盘的垃圾文件又不删除有用文件

在计算机使用过程中,随着时间的推移,C盘空间可能会被各种临时文件、缓存和无用的注册表项占用。这不仅会导致C盘空间不足,还可能影响计算机的性能。那么怎么样清理C盘内存空间,怎么样清理C盘的垃圾避开系统文件呢? 一…

手机自带录屏在哪?6个软件教你快速进行手机录屏

手机自带录屏在哪?6个软件教你快速进行手机录屏 手机自带的录屏功能可以让你轻松录制屏幕上的内容,记录游戏过程、制作教程或捕捉其他重要时刻。不同品牌的手机可能在不同位置提供录屏功能。以下是一些常见的手机品牌及其录屏功能位置,以及一…

【python 学习】快速了解python内置类型

🎬 鸽芷咕:个人主页 🔥 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 文章目录 前言一、内置类型的介绍1.1 类型体系1.2 空类型和None1.3 布尔值 二、内置类型的运算2.1 布尔运算2.2 比较运算符比较…

Avalonia开发实践(二)——开发带边框的Grid

一、开发背景 在实际开发工作中,常常会用到Grid进行布局。为了美观考虑,会给每个格子加上边框,如下图: 原生的Grid虽然有ShowGridLines属性可以控制显示格子之间的线,但线的样式不能定义,可以说此功能非常…

人声提取软件有哪些?4种人声提取软件轻松提取人声

在数字音乐与视频制作日益盛行的今天,人声提取软件成为了许多创作者不可或缺的工具。无论是想要从复杂的音乐中分离出纯净的人声,还是希望从视频中提取出精彩的对话片段,一款简单有效的人声提取工具尤为重要,下面给大家分享4种简单…

WTM的项目中EFCore如何适配人大金仓数据库

一、WTM是什么 WalkingTec.Mvvm框架(简称WTM)最早开发与2013年,基于Asp.net MVC3 和 最早的Entity Framework, 当初主要是为了解决公司内部开发效率低,代码风格不统一的问题。2017年9月,将代码移植到了.Net Core上&…

三菱FX3U进阶课程-运动控制讲解

如果你不会用三菱FX3U系列plc做运动控制,不会控制步进电机、不会控制伺服电机,那来学习本课程就对了,课程带你的价值是: 1、究竟PLC是怎么控制得了步进电机、伺服电机的?好奇怪啊,为啥别人会,我…

WANGLS

DHCP 动态主机配置协议 原理 网络 网络是双向的,网络是有方向的 广播;广播是由种类的,广播是有范围的的 租约的建立——租约的相应、租约的选择——租约的完成 租约的建立:租约的请求 有客户端发出 DHCP discover 广播、寻找服务器 租约的响应 收到响应,不是服务器,…

Revit 2025:建筑设计师的得力助手

在这繁忙的现代社会中,建筑设计师们总是追求着更高效、更精确的工具。而Revit 2025,正如一位老友般,默默地陪伴在我们身边,帮助我们实现心中的蓝图。今天,我怀着满腔的热情与感激,向大家介绍这款软件的功能…

越低越好?所以伦敦金至少可以入金多少呢?

投资者要进行黄金投资,市场中有多个品种可以选择。笔者认为,在众多品种之中,伦敦金是一种适应性比较广的黄金投资方式。如果投资者要选择伦敦金作为自己的黄金投资的主要方式,那么有一些就基本的问题是我们需要了解的,…

Retrofit框架源码深度剖析【Android热门框架分析第二弹】

Android热门框架解析,你确定不来看看吗? OkHttp框架源码深度剖析【Android热门框架分析第一弹】 Retrofit框架源码深度剖析【Android热门框架分析第二弹】 什么是Retrofit? 准确来说,Retrofit 是一个 RESTful 的 HTTP 网络请求…

R包:reticulate R对python的接口包

介绍1 R和python是两种不同的编程语言,前者是统计学家发明并且服务数学统计计算,后者则是最万能的胶水语言。随着大数据时代的到来,两者在数据分析领域存在越来越多的共同点且可以相互使用,为了破解二者的编程壁垒,CR…

Noah-MP陆面生态水文模拟与多源遥感数据同化

陆面模型在生态水文研究中的地位和作用;熟悉模型的发展历程,常见模型及各自特点;理解Noah-MP模型的原理,掌握Noah-MP模型在单站和区域的模拟、模拟结果的输出和后续分析及可视化等方法;课程还将深入讲解数据同化的原理…

从天空到地面:无人机航拍推流直播技术在洞庭湖决口封堵中的全方位支援

据新闻报道,受持续强降雨影响,湖南省华容县团洲垸洞庭湖一线堤防发生管涌险情,随后出现决口。截至7月8日20时左右,226米长的洞庭湖一线堤防决口已累计进占208米,目前剩余18米,有望在今晚或9日凌晨实现合龙。…

Spring Cloud Alibaba -- 分布式定时任务解决方案(轻量级、快速构建)(ShedLock 、@SchedulerLock )

文章目录 一、 ShedLock简介二、 SchedulerLock三、基于Mysql方式使用步骤1.建表2.引入依赖3.Mysql连接配置4.ScheduledLock配置5.启动类配置6.创建定时任务7.启动多个项目服务进行测试8.SchedulerLock注解说明 四、使用注意事项 一、 ShedLock简介 ShedLock 是一个用于 Java …

swiftui给视图添加边框或者只给某个边设置border边框

直接使用border()就可以给一个视图添加边框效果,但是这种边框会给所有的边都设置上。 border()里面也可以添加属性.border(.blue, width: 5)这种就是设置颜色和宽度。 设置圆角边框 Text("1024小神").padding().cornerRadius(20).overlay(RoundedRectang…

如何在Facebook上保护你的个人资料安全?

随着社交媒体的普及和个人信息的数字化,保护个人资料安全成为越来越重要的议题。特别是在使用像Facebook这样的平台时,我们需要特别注意如何保护我们的数据免受未经授权的访问和滥用。本文将探讨一些实用的方法,以及如何增强你在Facebook上的…

keil mdk注释插件合集格式、时间、日期注释

文章目录 一、前言二、安装步骤2.1 解压tools.zip2.2 tools 文件解释2.3 添加注释带keil 三、配置3.1 格式化代码3.2 文件注释3.3函数注释3.4 当前日期3.5 当前时间 四、编辑注释模板4.1 编辑函数注释模板4.2 编辑C文件注释模板4.3 编辑h文件注释模板 五、为注释功能添加快捷键…

qmt量化交易策略小白学习笔记第55期【qmt编程之期权数据--获取历史期权列表】

qmt编程之获取期权数据 qmt更加详细的教程方法,会持续慢慢梳理。 也可找寻博主的历史文章,搜索关键词查看解决方案 ! 感谢关注,咨询免费开通量化回测与获取实盘权限,欢迎和博主联系! 获取历史期权列表 …

Sui DeFi现状介绍

关于Sui Network Sui是基于第一原理重新设计和构建而成的L1公有链,旨在为创作者和开发者提供能够承载Web3中下一个十亿用户的开发平台。Sui上的应用基于Move智能合约语言,并具有水平可扩展性,让开发者能够快速且低成本支持广泛的应用开发。获…