02Mysql之多表查询--例题讲解
一、题目详情,以及表的建立
新增员工表emp和部门表deptcreate 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.找出销售部门中年纪最大的员工的姓名
mysql> select name -> from emp -> where dept2=102-> order bt age desc-> limit;

-
select e.name: 这是查询的主体部分,表示我们希望从表中选择特定的列(在这种情况下是 "name" 列)作为结果。 -
from emp e: 这部分指定了我们要从 "emp" 表中检索数据,并使用 "e" 作为该表的别名。这使得在查询中可以使用 "e" 来引用 "emp" 表。 -
join dept d on e.dept2 = dept1: 这是一个连接操作,它将 "emp" 表与 "dept" 表连接起来。我们使用了 "JOIN" 子句来连接这两个表,然后使用 "on" 子句指定连接的条件,即 "e.dept2"(员工所属部门)等于 "dept1"(部门表的部门编号)。 -
where d.dept_name = '销售': 这是一个筛选条件,它限制了只选择 "dept_name" 列等于 '销售' 的部门。 -
order by e.age desc: 这部分指定了对结果进行排序。"ORDER BY" 子句后面跟着要用于排序的列名,这里是 "e.age" 列(员工年龄)。"desc" 表示按降序排列,即从高到低排列。 -
limit 1: 这部分限制了结果的数量,仅返回第一个满足条件的行。由于我们使用了降序排序,所以这将返回年龄最大的员工。
2.求财务部门最低工资的员工姓名
SELECT name
FROM emp
WHERE dept2 = 101
ORDER BY incoming
LIMIT 1;

3.列出每个部门收入总和高于9000的部门名称
SELECT dept_name
FROM dept
WHERE dept1 IN (SELECT dept2FROM empGROUP BY dept2HAVING SUM(incoming) > 9000
);

4.求工资在7500到8500元之间,年龄最大的人的姓名及部门
SELECT e.name, d.dept_name
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
WHERE e.incoming BETWEEN 7500 AND 8500
ORDER BY e.age DESC
LIMIT 1;

5.找出销售部门收入最低的员工入职时间
SELECT MIN(worktime_start)
FROM emp
WHERE dept2 = 102
ORDER BY incoming
LIMIT 1;

6.财务部门收入超过2000元的员工姓名
SELECT name
FROM emp
WHERE dept2 = 101 AND incoming > 2000;

7.列出每个部门的平均收入及部门名称
SELECT d.dept_name, AVG(e.incoming) AS avg_incoming
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
GROUP BY d.dept_name;

8.IT技术部入职员工的员工号
SELECT sid
FROM emp
WHERE dept2 = 103;

9.财务部门的收入总和;
SELECT SUM(incoming) AS total_incoming
FROM emp
WHERE dept2 = 101;

10.先按部门号大小排序,再依据入职时间由早到晚排序员工信息表
SELECT e.sid, e.name, e.age, e.worktime_start, e.incoming, e.dept2, d.dept_name
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
ORDER BY e.dept2, e.worktime_start;

11.找出哪个部门还没有员工入职;
SELECT d.dept_name
FROM dept d
LEFT JOIN emp e ON d.dept1 = e.dept2
WHERE e.sid IS NULL;

12.列出部门员工收入大于7000的部门编号,部门名称;
SELECT d.dept1, d.dept_name
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
WHERE e.incoming > 7000
GROUP BY d.dept1, d.dept_name;

13.列出每一个部门的员工总收入及部门名称;
SELECT d.dept_name, SUM(e.incoming) AS total_incoming
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
GROUP BY d.dept_name;

14.列出每一个部门中年纪最大的员工姓名,部门名称;
SELECT d.dept_name, e.name
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
WHERE e.age = (SELECT MAX(age)FROM empWHERE dept2 = d.dept1
);

15.求李四的收入及部门名称
SELECT e.incoming, d.dept_name
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
WHERE e.name = '李四';

16.列出每个部门中收入最高的员工姓名,部门名称,收入,并按照收入降序
SELECT d.dept_name, e.name, e.incoming
FROM emp e
INNER JOIN dept d ON e.dept2 = d.dept1
WHERE e.incoming = (SELECT MAX(incoming)FROM empWHERE dept2 = d.dept1
)
ORDER BY e.incoming DESC;

17.列出部门员工数大于1个的部门名称
SELECT d.dept_name
FROM dept d
INNER JOIN emp e ON d.dept1 = e.dept2
GROUP BY d.dept_name
HAVING COUNT(*) > 1;

19.查找张三所在的部门名称
相关文章:
02Mysql之多表查询--例题讲解
一、题目详情,以及表的建立 新增员工表emp和部门表deptcreate 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,销售)…...
虹科方案 | 汽车总线协议转换解决方案
汽车总线: 汽车总线是一种用于在车辆电子系统中传输数据和控制信息的通信系统。它允许不同的电子控制单元(ECU)在车辆中相互通信,协调各个系统的操作,以实现功能的集成和协同工作。 在现代汽车中,综合通信…...
Mr. Cappuccino的第59杯咖啡——简单手写SpringIOC框架
简单手写SpringIOC框架 环境搭建基于XML方式项目结构项目代码运行结果 基于注解方式项目结构项目代码运行结果 简单手写SpringIOC框架核心原理基于XML方式原理项目结构项目代码运行结果 基于注解方式原理项目结构项目代码运行结果 环境搭建 基于XML方式 项目结构 项目代码 p…...
爬虫 学习HTML标签和元素的基本概念,了解网页的结构和内容
HTML(Hypertext Markup Language)是一种用于创建网页的标记语言,由一系列的标签组成。标签使用尖括号(< 和 >)包围,并且通常成对出现,一个是开始标签,一个是结束标签。 HTML文…...
mysql将id重新修改为递增
文章目录 场景解决,排序的话可以先按照一定大小改一下,然后将id字段删掉,再重新生成即可清空表数据,并将自增id改为1开始 场景 好比我有个配置表: CREATE TABLE config (id int NOT NULL AUTO_INCREMENT,config_key varchar(20) NOT NULL,config_value varchar(500) NOT NU…...
http、https笔记
目录 HTTP 基本概念状态码:get和post的区别:http 常⻅字段:http的缺点: HTTP/1.1HTTP/3HTTPSHTTPS和HTTP区别对称加密和⾮对称加密⾮对称加密 HTTP 基本概念 状态码: 1xx 中间状态,比如post的continue 20…...
飞凌嵌入式「国产」嵌入式核心板大盘点(三)——龙芯中科、赛昉科技
为了帮助各位工程师朋友详细了解飞凌嵌入式推出的“国产化”产品,小编专门开设了「国产平台大盘点专题」。上周,已经带大家盘点了飞凌嵌入式联合瑞芯微电子和全志科技两个国产处理器品牌打造的平台,今天,将继续为大家介绍龙芯和赛…...
以vue2为例,用npm开发环境在后端部署vue2项目(更推荐使用nginx部署)
因为之前一致出现的跨域问题,从而想到了这个办法,属于偏方。推荐使用nginx部署,再去解决跨域问题。 接下来聊一聊本文所使用的方法。 首先将你的前端vue项目拷贝一份到服务器,准备一个dockerfile文件,用这个进行部署首…...
docker容器监控:Cadvisor +Prometheus+Grafana的安装部署
目录 Cadvisor PrometheusGrafana的安装部署 一、安装docker: 1、安装docker-ce 2、阿里云镜像加速器 3、下载组件镜像 4、创建自定义网络 二、部署Cadvisor 1、被监控主机上部署Cadvisor容器 2、访问cAdvisor页面 三、安装prometheus 1、部署Prometheus…...
前端食堂技术周刊第 93 期:7 月登陆 Web 平台的新功能、Node.js 工具箱、Nuxt3 开发技巧、MF 重构方案
美味值:🌟🌟🌟🌟🌟 口味:橙橙冰萃美式 食堂技术周刊仓库地址:https://github.com/Geekhyt/weekly 大家好,我是童欧巴。欢迎来到前端食堂技术周刊,我们先来…...
获取 Android 的 SHA1 值
1、调试版,可以直接在 Android studio 中的 gradle 中查看。也可以用下面方法进行 前提要先确定签名文件所在的路径:调试版默认使用的签名文件是debug.keystore,文件处于 C 盘用户目录下的.android文件夹下。打开命令行工具, 1、…...
! [remote rejected] develop -> develop (pre-receive hook declined)
问题 git push 远程提交dao develop 分支失败,出现下面错误信息 remote: GitLab: You are not allowed to push code to protected branches on this project. To https://xxx.com.cn/xxx/xxx/xxx/xxx.git/! [remote rejected] develop -> develop (pre-receiv…...
最强的表格组件—AG Grid使用以及License Key Crack
PS: 想要官方 License Key翻到最后面 Ag Grid简介 Ag-Grid 是一个高级数据网格,适用于JavaScript/TypeScript应用程序,可以使用React、Angular和Vue等流行框架进行集成。它是一种功能强大、灵活且具有高度可定制性的表格解决方案,提供了丰富…...
【算法】逆波兰表达式
文章目录 定义求法代码思想: 定义 逆波兰表达式也称为“后缀表达式”,是将运算符写在操作数之后的运算式。 求法 *如:(ab)c-(ab)/e的转换过程: 先加上所有的括号。 (((ab)*c)-((ab)/e))将所有的运算符移到括号外面 (((ab) c)* …...
添加SQLCipher 到项目中
文章目录 一、克隆下载SQLCipher二、手动导入1. 生成sqlite3.c2. 在项目中添加命令3. 添加 Security.framework 三、CocoaPods导入 SQLCipher官方地址 一、克隆下载SQLCipher $ cd ~/Documents/code $ git clone https://github.com/sqlcipher/sqlcipher.git二、手动导入 1.…...
轻松预约,尽享美食,详解餐厅预约小程序的设计与实现
随着智能手机的普及和人们生活水平的提高,餐厅预约已经成为人们日常生活中的一部分。为了更好地满足人们的需求,许多餐厅开始使用小程序来提供更方便快捷的预约服务。本文将介绍如何制作一款餐厅预约小程序的详细步骤。 1. 进入乔拓云网后台,…...
数据结构--栈和队列3.1(栈-顺序结构)
目录 栈(Stack)栈顶(top)栈底(bottom)空栈(不含任何元素) 创建栈 入栈操作 出栈操作 销毁一个栈 计算栈的当前容量 实例分析 栈的插入操作叫做进栈(Push…...
pdf怎么压缩到1m?这样做压缩率高!
PDF是目前使用率比较高的一种文档格式,因为它具有很高的安全性,还易于传输等,但有时候当文件体积过大时,会给我们带来不便,这时候简单的解决方法就是将其压缩变小。 想要将PDF文件压缩到1M,也要根据具体的情…...
AttentionFreeTransformer 源码解析(一):AFTFull、AFTSimple、AFTLocal
我觉得源码写的很好懂,我就不加注释了,直接上计算流程图。 AFTFull class AFTFull(nn.Module):def __init__(self, max_seqlen, dim, hidden_dim64):super().__init__()max_seqlen: the maximum number of timesteps (sequence length) to be fed indim…...
C++ 计算 拟合优度R^2
解决的问题: 拟合优度(Goodness of Fit)是指回归直线对观测值的拟合程度,度量拟合优度的统计量是可决系数(亦称确定系数) R?。R最大值为 1。R%的值越接近1,说明回归直线对观测值的拟合程度越好,反之,R%值越小&#x…...
Zustand 状态管理库:极简而强大的解决方案
Zustand 是一个轻量级、快速和可扩展的状态管理库,特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...
FFmpeg 低延迟同屏方案
引言 在实时互动需求激增的当下,无论是在线教育中的师生同屏演示、远程办公的屏幕共享协作,还是游戏直播的画面实时传输,低延迟同屏已成为保障用户体验的核心指标。FFmpeg 作为一款功能强大的多媒体框架,凭借其灵活的编解码、数据…...
前端导出带有合并单元格的列表
// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...
蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练
前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...
《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...
Robots.txt 文件
什么是robots.txt? robots.txt 是一个位于网站根目录下的文本文件(如:https://example.com/robots.txt),它用于指导网络爬虫(如搜索引擎的蜘蛛程序)如何抓取该网站的内容。这个文件遵循 Robots…...
C++.OpenGL (10/64)基础光照(Basic Lighting)
基础光照(Basic Lighting) 冯氏光照模型(Phong Lighting Model) #mermaid-svg-GLdskXwWINxNGHso {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-GLdskXwWINxNGHso .error-icon{fill:#552222;}#mermaid-svg-GLd…...
Spring Boot+Neo4j知识图谱实战:3步搭建智能关系网络!
一、引言 在数据驱动的背景下,知识图谱凭借其高效的信息组织能力,正逐步成为各行业应用的关键技术。本文聚焦 Spring Boot与Neo4j图数据库的技术结合,探讨知识图谱开发的实现细节,帮助读者掌握该技术栈在实际项目中的落地方法。 …...
【HTML-16】深入理解HTML中的块元素与行内元素
HTML元素根据其显示特性可以分为两大类:块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...
