【SQL】多表查询案例
📢本章节主要学习使用SQL多表查询的案例,多表查询基础概念 请点击此处。
🎄数据准备
- 首先我们创建一个新的表也就是薪资等级表,其余两个表(员工表和薪资表)在多表查询章节中已经创建。
- 然后我么根据这三个表完成下面的12个需求。
create table salaryGrade(grade int,losal int,hisal int
)comment '薪资等级表';insert into salaryGrade values (1,0,3000),(2,3001,5000),(3,5001,8000),(4,8001,10000),(5,10001,15000),(6,15001,20000),(7,20001,25000),(8,25001,30000);
🎄案例
⭐案例1
select employee.name,employee.age,employee.job,department.name from employee,department
where employee.dept_id = department.id; ⭐案例2
select e.name,e.age,e.job,d.name from
employee as e join department as don (e.dept_id = d.id and e.age < 30); - 还有一种是在on子句后面加where条件
select e.name,e.age,e.job,d.name from
employee as e join department as don e.dept_id = d.id where e.age > 30; ⭐案例3
- 这里有个重点要使用distinct对查出的列进行去重操作。
- 对于distinct来说是它后面所有的列都完全相同时才会去重。
select distinct department.id, department.name from employee,department
where employee.dept_id = department.id ⭐案例4
📢查询所有年龄大于40岁的员工, 及其归属的部门名称; 如果员工没有分配部门, 也需要展示出
select e.*,department.name from (select * from employee where employee.age > 40) as eleft outer join department on e.dept_id = department.id; - 还有一种实现方式更为简单
select employee.*,department.name from employee left outer join departmenton employee.dept_id = department.id where employee.age > 40 ⭐案例5
📢查询所有员工的工资等级
select employee.*,salaryGrade.grade from employee,salarygradewhere employee.salary between salaryGrade.losal and salaryGrade.hisal; ⭐案例6
- 首先涉及到3个表,3个表的连接条件至少有两个,先确定连接条件
- 连接条件:(employee.salary between salaryGrade.losal and salaryGrade.hisal) and department.id = employee.dept_id
- 查询条件:department.name = '研发部'
select employee.*,salaryGrade.grade from employee ,department,salaryGrade
where (employee.salary between salaryGrade.losal and salaryGrade.hisal) and department.id = employee.dept_id
and department.name = '研发部' ⭐案例7
select department.name, avg(employee.salary) as '平均工资'
from employee,department
where employee.dept_id = department.idand department.name = '研发部';/* 每个部门平均工资 */
select department.name, avg(employee.salary) as '平均工资'
from employee,department
where employee.dept_id = department.id
group by employee.dept_id; ⭐案例8
- 这是一个典型的标量子查询,因为返回的值只有一个值。
select name from employee where salary > (
select salary from employee where name = '灭绝') - 当然这个也可以使用自查询,只不过比子查询要复杂
select a.name from employee as a join employee as b on a.salary > b.salary where b.name = '灭绝' ⭐案例9
select name from employee where salary > (select avg(salary) from employee); ⭐案例10
select * from employee as a where a.salary <
(select avg(b.salary) from employee as b where b.dept_id = a.dept_id) - 还可以使用分组查询+自连接
select a.* from employee as a join
(select employee.dept_id,avg(employee.salary) as avg_salary from employee group by dept_id )
as b on a.dept_id = b.dept_id
where a.salary < b.avg_salary ⭐案例11
- 这里使用的子查询属于select类型。
select a.id, a.name, (select count(*) from employee as b where b.dept_id = a.id) as '部门人数'
from department as a; ⭐案例12
- 首先我们先把三张表的连接条件写出来。
- 然后再去写表的查询条件。这个案例不需要写查询条件。
select student.name, student_course.studentno, student_course.courseno
from student,course,student_course
where student.no = student_course.studentnoand course.name = student_course.courseno 相关文章:
【SQL】多表查询案例
📢本章节主要学习使用SQL多表查询的案例,多表查询基础概念 请点击此处。 🎄数据准备 首先我们创建一个新的表也就是薪资等级表,其余两个表(员工表和薪资表)在多表查询章节中已经创建。然后我么根据这三个表完成下面的12个需求。 create tab…...
springboot系列十四: 注入Servlet, Filter, Listener + 内置Tomcat配置和切换 + 数据库操作
文章目录 注入Servlet, Filter, Listener官方文档基本介绍使用注解方式注入使用RegistrationBean方法注入DispatcherServlet详解 内置Tomcat配置和切换基本介绍内置Tomcat配置通过application.yml完成配置通过类配置 切换Undertow 数据库操作 JdbcHikariDataSource需求分析应用…...
力扣-贪心-53 最大子数组和
思路 先把每一个值都加到当前集合中,记录当前的和,直到当前记录和小于0了,再重置改记录,再次尝试累加 代码 class Solution { public:int maxSubArray(vector<int>& nums) {int res INT32_MIN;int curSum 0;for(in…...
吃一堑长一智
工作中经历,有感触记录下 故事一 以前在一家公司时,自己是一名开发人员,遇到问题请教领导解决方案,当时领导给了建议,后来上线后出问题了,背了锅。心里想的是领导说这样做的呀,为什么出问题还…...
aws(学习笔记第二十九课) aws cloudfront hands on
aws(学习笔记第二十九课) 使用aws cloudfront 学习内容: 什么是aws cloudfront练习使用aws cloudfront 1. 什么是aws cloudfront aws cloudfront的整体架构 这里可以看出,aws引入了edge location的概念,用户的client与edge location进行是…...
deepseek自动化代码生成
使用流程 效果第一步:注册生成各种大模型的API第二步:注册成功后生成API第三步:下载vscode在vscode中下载agent,这里推荐使用cline 第四步:安装完成后,设置模型信息第一步选择API provider: Ope…...
【C++八股】内存对⻬
内存对齐是指编译器按照特定规则安排数据在内存中的存储位置,以提高程序的执行效率和可移植性。 内存对齐的原因: 1. 性能优化: 现代处理器通常要求数据在内存中按照特定的边界对齐,以提高内存访问效率。 如果数据未对齐&#x…...
idea连接gitee后.反向创建仓库和分支
文章目录 自动关联你登录的账号填写你的仓库和分支完成后会在gitee上创建一个仓库 (使用idea远程兼容gitee并反向创建仓库和分支) 自动关联你登录的账号 填写你的仓库和分支 完成后会在gitee上创建一个仓库...
汽车自动驾驶辅助L2++是什么?
自动驾驶辅助级别有哪些? 依照SAE(SAE International,Society of Automotive Engineers国际自动机工程师学会)的标准,大致划分为6级(L0-L5): L0人工驾驶:即没有驾驶辅助…...
围棋打谱应用软件设计制作
围棋打谱应用软件设计制作 五子棋游戏是大家耳熟能详的游戏,深受大众喜爱。可见其在智能游戏中的地位。我在本站发了好几篇文章介绍编制方法和算法。而类似的围棋游戏则是智能游戏的顶级存在。今在此基础上编制一款围棋打谱软件。当然这是简单的游戏程序࿰…...
论文笔记-WSDM2025-ColdLLM
论文笔记-WSDM2025-Large Language Model Simulator for Cold-Start Recommendation ColdLLM:用于冷启动推荐的大语言模型模拟器摘要1.引言2.前言3.方法3.1整体框架3.1.1行为模拟3.1.2嵌入优化 3.2耦合漏斗ColdLLM3.2.1过滤模拟3.2.2精炼模拟 3.3模拟器训练3.3.1LLM…...
线代[8]|北大丘维声教授《怎样学习线性代数?》(红色字体为博主注释)
文章目录 说明一、线性代数的内容简介二、学习线性代数的用处三、线性代数的特点四、学习线性代数的方法五、更新时间记录 说明 文章中红色字体为博主敲录完丘教授这篇文章后所加,刷到这篇文章的读者在首次阅读应当跳过红色字体,先通读一读文章全文&…...
使用 C++ 和 gRPC 的常见陷阱及解决方案
文章目录 1. 环境配置的陷阱1.1 依赖版本冲突或混淆1.2 gRPC 工具缺失 2. 编译和链接的陷阱2.1 运行时库不匹配(/MT vs /MD)2.2 未解析的外部符号 3. Protobuf 文件生成的陷阱3.1 工具版本不匹配3.2 生成文件运行时库不一致 4. 运行时的陷阱4.1 缺少 DLL…...
《深度学习实战》第2集:卷积神经网络(CNN)与图像分类
《深度学习实战》第2集:卷积神经网络(CNN)与图像分类 引言 卷积神经网络(Convolutional Neural Network, CNN)是深度学习在计算机视觉领域的核心工具。从早期的 LeNet 到现代的 ResNet 和 Vision Transformer…...
AD(Altium Designer)器件封装——立创商城导出原理图和PCB完成器件封装操作指南
目录 1、立创商城下载原理图和PCB图 1.1 打开立创商城 1.2 寻找所需器件 1.3 确定所需芯片 1.4 打开原理图和PCB图 1.5 导出原理图 1.6 确定导出为AD文件 1.7 下载成功 1.8 导出PCB 1.9 确定导出为AD文件 1.10 原理图PCB下载成功 2、原理图和PCB图预处理 2.1 复制…...
DeepSeek掘金——调用DeepSeek API接口 实现智能数据挖掘与分析
调用DeepSeek API接口:实现智能数据挖掘与分析 在当今数据驱动的时代,企业和开发者越来越依赖高效的数据挖掘与分析工具来获取有价值的洞察。DeepSeek作为一款先进的智能数据挖掘平台,提供了强大的API接口,帮助用户轻松集成其功能到自己的应用中。本文将详细介绍如何调用D…...
LangChain系列:精通LangChain的合并文档链
LangChain的合并链旨在解决语言模型处理长文本时的上下文限制问题,包含Stuff、MapReduce、Refine和Rerank四种策略。Stuff链通过简单拼接文档块实现快速处理,适用于短文本但受限于模型token容量;MapReduce链采用分治思想,先独立处…...
rtcwake - Linux下定时唤醒计算机
rtcwake 是一个用于通过实时时钟(RTC)唤醒计算机的工具。它常用于在 Linux 系统中设置计算机在指定时间自动唤醒或关闭。以下是对命令 rtcwake -m off -s ${sleep_time} 的详细解析: 命令解析 bash复制 rtcwake -m off -s ${sleep_time} 1…...
MATLAB在投资组合优化中的应用:从基础理论到实践
引言 投资组合优化是现代金融理论中的核心问题之一,旨在通过合理配置资产,实现风险与收益的最佳平衡。MATLAB凭借其强大的数学计算能力和丰富的金融工具箱,成为投资组合优化的理想工具。本文将详细介绍如何使用MATLAB进行投资组合优化&#…...
什么是“可迭代”
在 Python 中,“可迭代”(Iterable)是一个非常重要的概念,它指的是任何可以被逐个访问其元素的对象。换句话说,如果一个对象支持迭代操作(比如可以通过 for 循环逐个访问其元素),那么…...
Midscene性能调优实战:从卡顿到流畅的自动化体验
Midscene性能调优实战:从卡顿到流畅的自动化体验 【免费下载链接】midscene AI-powered, vision-driven UI automation for every platform. 项目地址: https://gitcode.com/GitHub_Trending/mid/midscene 当你的自动化脚本运行缓慢,AI操作响应延…...
【限时解密】ISO WG21草案最新变动:C++26合约语义将在2024年10月冻结,你现在不学就错过最后窗口期
更多请点击: https://intelliparadigm.com 第一章:C26合约编程的演进脉络与冻结节点意义 C26 将首次正式纳入“合约(Contracts)”作为语言级特性,标志着 ISO C 标准在运行时契约保障机制上的关键落地。该特性并非凭空…...
80亿融资涌入脑机接口,强脑科技成国内独角兽,如何改变500万残疾人命运?
01 脑机接口,为何突然又火了?先说结论:这波热,不是凭空来的。它背后其实是几股力量,同时在往一个点挤。马斯克在2016年做的Neuralink,比强脑还晚一年半,到2026年已宣布要量产,将脑机…...
MediaPipe-TouchDesigner终极指南:解决摄像头输入与GPU加速的完整教程
MediaPipe-TouchDesigner终极指南:解决摄像头输入与GPU加速的完整教程 【免费下载链接】mediapipe-touchdesigner GPU Accelerated MediaPipe Plugin for TouchDesigner 项目地址: https://gitcode.com/gh_mirrors/me/mediapipe-touchdesigner 在实时计算机视…...
从天线到滤波器:详解CST微波工作室中Open边界与Open(add space)的应用场景与设置细节
从天线到滤波器:详解CST微波工作室中Open边界与Open(add space)的应用场景与设置细节 在电磁仿真领域,边界条件的设置往往决定着计算结果的准确性与计算效率的平衡。对于使用CST微波工作室的中级用户来说,Open与Open(add space)这对看似相似却…...
GLM-4.1V-9B-Base作品集:面向开发者的技术文档截图理解与要点提炼
GLM-4.1V-9B-Base作品集:面向开发者的技术文档截图理解与要点提炼 1. 视觉多模态理解新利器 在技术文档处理领域,开发者经常面临大量包含截图、图表和示意图的文档。传统方式需要人工阅读和理解这些视觉内容,效率低下且容易出错。GLM-4.1V-…...
Spring Boot项目里Jackson的@JsonFormat注解突然不灵了?排查后发现是Gson在‘搞鬼’
Spring Boot项目中Jackson的JsonFormat注解失效:Gson冲突的深度排查指南 问题现象:当日期格式化突然"罢工" 上周三凌晨两点,我被一通紧急电话吵醒。团队里的小王在电话那头焦急地说:"线上订单系统的创建时间全部变…...
Linux内核 命名空间机制
Linux Namespace 是内核提供的轻量级资源隔离机制,核心是让不同进程组看到独立的系统资源视图,是容器(Docker、K8s)的底层基石。它隔离的是进程对资源的可见性,而非物理资源本身,因此比虚拟机更轻量化本质&…...
人IgE His标签蛋白如何助力肿瘤免疫疗法创新?
一、过敏反应与肿瘤免疫有何内在关联?过敏反应是机体免疫系统对花粉、海鲜、尘螨等环境抗原产生的过度防卫现象,临床表现为打喷嚏、皮疹甚至呼吸困难等症状。这一现象的免疫学基础在于肥大细胞的快速应答机制。作为免疫系统中的“哨兵”,肥大…...
3分钟快速上手:ES-Client——简单高效的Elasticsearch桌面客户端完整指南
3分钟快速上手:ES-Client——简单高效的Elasticsearch桌面客户端完整指南 【免费下载链接】es-client elasticsearch客户端,issue请前往码云:https://gitee.com/qiaoshengda/es-client 项目地址: https://gitcode.com/gh_mirrors/es/es-cli…...
