MySQL -- 复合查询及内外连接

news2025/1/22 19:12:57

MySQL – 复合查询及内外连接

文章目录

  • MySQL -- 复合查询及内外连接
  • 一、基本查询回顾
    • 1.单表查询
  • 二、多表查询
    • 1.表的组合
    • 2.案例
  • 三、自连接
    • 1.案例
    • 四、子查询
    • 1.单行子查询
    • 2.多行子查询
    • 3.多列子查询
    • 4.在from子句中使用子查询
    • 5.合并查询
  • 五、内连接
  • 六、外连接
    • 1.左外连接
    • 2.右外连接


一、基本查询回顾

1.单表查询

  • 查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J:
    在这里插入图片描述

  • 按照部门号升序而雇员的工资降序排序:
    在这里插入图片描述

  • 使用年薪进行降序排序:
    在这里插入图片描述

  • 显示工资最高的员工的名字和工作岗位:
    注:select支持嵌套;
    别名只在距离最近的select的上下文奏效,并不是在整个表达式奏效;

    在这里插入图片描述

  • 显示工资高于平均工资的员工信息:
    在这里插入图片描述

  • 显示每个部门的平均工资和最高工资:
    在这里插入图片描述

  • 显示平均工资低于2000的部门号和它的平均工资:
    在这里插入图片描述

  • 显示每种岗位的雇员总数,平均工资:
    在这里插入图片描述

二、多表查询

1.表的组合

多表查询的关键点在于:将两张表组合起来,形成一张表;
在这里插入图片描述
如上图所示,两张表的组合形成了数据穷举;
在这里插入图片描述
两张表根据外键一一进行组合,就是数据穷举;

注:

  • 如果字段在多表中是唯一的,前面就不需要加表前缀,否则需要加表前缀;
  • 可以给表起别名;

2.案例

  • 显示雇员名、雇员工资以及所在部门的名字:
    因为上面的数据来自EMP和DEPT表,因此要联合查询;
    在这里插入图片描述
  • 显示部门号为10的部门名,员工名和工资:
    在这里插入图片描述
  • 显示各个员工的姓名,工资,及工资级别:
    在这里插入图片描述

三、自连接

自连接是指在同一张表连接查询;

1.案例

  • 显示员工FORD的上级领导的编号和姓名:
    • 使用子查询:
      在这里插入图片描述
    • 使用多表查询(自查询):
      from emp leader, emp worker,给自己的表起别名,因为要先做笛卡尔积,所以别名可以先识别;
      在这里插入图片描述

四、子查询

MySQL表查询的思想:MySQL查询永远只有一张表,无论是一张表的select子查询,还是多张表查询,本质都是整合进一张表进行查询;

子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询;

1.单行子查询

子查询的结果只返回一行记录;

  • 显示SMITH同一部门的员工:
    在这里插入图片描述

2.多行子查询

子查询的结果返回多行记录;0
共有三个关键字:in,all,any;

  • in关键字:只要父查询指定条件在这个结果集合中,就显示出来
    查询和10号部门的工作岗位相同的雇员的名字,岗位,工资,部门号,但是不包含10自己的;
    在这里插入图片描述

  • all关键字:子查询出来的结果作为一个集合,意为比所有人都要…
    显示工资比部门30的所有员工的工资高的员工的姓名、工资和部门号;
    在这里插入图片描述

  • any关键字:子查询出来的结果作为一个集合,意为比其中任意一个…
    显示工资比部门30的任意员工的工资高的员工的姓名、工资和部门号(包含自己部门的员工)
    在这里插入图片描述

3.多列子查询

单行子查询是指子查询只返回单列,单行数据;多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句;

  • 查询和SMITH的部门和岗位完全相同的所有雇员,不含SMITH本人:
    在这里插入图片描述
    用括号可以达成多列比较的条件

4.在from子句中使用子查询

子查询语句出现在from子句中;这里要用到数据查询的技巧,把一个子查询当做一个临时表使用;

  • 显示每个高于自己部门平均工资的员工的姓名、部门、工资、平均工资:
    获取各个部门的平均工资,将其看作临时表;
    在这里插入图片描述
  • 查找每个部门工资最高的人的姓名、工资、部门、最高工资:
    在这里插入图片描述
  • 显示每个部门的信息(部门名,编号,地址)和人员数量:
    • 方法1:使用多表:
      在这里插入图片描述
  • 方法2:使用子查询:
    对emp表进行人员统计;
    在这里插入图片描述
    将上面的表看作临时表:
    在这里插入图片描述

5.合并查询

在实际应用中,为了合并多个select的执行结果,可以使用集合操作符 union,union all;
本质作用:就是将多次查询结果合并成为一个结果;

  • union:该操作符用于取得两个结果集的并集;当使用该操作符时,会自动去掉结果集中的重复行;
    将工资大于2500或职位是MANAGER的人找出来;
    在这里插入图片描述
  • union all:该操作符用于取得两个结果集的并集;当使用该操作符时,不会去掉结果集中的重复行;
    将工资大于25000或职位是MANAGER的人找出来:
    在这里插入图片描述

五、内连接

内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我们前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。

语法:

select 字段 from1 inner join2 on 连接条件 and 其他条件;
  • 显示SMITH的名字和部门名称:
    • 前面的写法:
      在这里插入图片描述

    • 标准内连接写法:
      在这里插入图片描述

六、外连接

外连接分为左外连接和右外连接;

1.左外连接

如果联合查询,左侧的表完全显示我们就说是左外连接;
语法:

select 字段名 from 表名1 left join 表名2 on 连接条件
  • 案例:
    建两张表:
    在这里插入图片描述
    查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来;
    在这里插入图片描述

2.右外连接

如果联合查询,右侧的表完全显示我们就说是右外连接;

  • 对stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来:
    在这里插入图片描述

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

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

相关文章

C语言程序设计(第五版)谭浩强 第三章课后题答案

第三章 1、假如我国国民生产总值的年增长率为7%&#xff0c; 计算10年后我国国民生产总值与现在相比增长多少百分比。计算公式为 ,其中r为年增长率&#xff0c;n为年数&#xff0c;p为与现在相比的倍数。 #include<stdio.h> #include<math.h>int main(){float r,…

基于QT的简易计算器(一)

目录 0 简介1.设计原理1.1界面设计1.1.1界面基本布局1.1.2 界面调整和美化1.1.2 控件重命名 1.2 连接信号和槽1.3 软件逻辑1.3.1四则运算1.3.2 连续运算&#xff08;不完全&#xff09;的原理1.3.3 清屏1.3.4 退格1.3.5 等于1.3.6 小数点 2.总结与拓展 0 简介 最近在学QT&…

数字化浪潮下,AI数字人融入多元化应用场景

随着AI数字人技术的发展&#xff0c;各个行业都在不断挖掘数字人更多的潜力&#xff0c;VR全景中的AI数字人功能逐渐成为了一种新颖的用户交互方式。AI数字人将企业的文化、品牌价值、商业服务等充分结合为一体&#xff0c;为企业提供了全新的机会&#xff0c;从客户互动到营销…

VueX中的getters配置项

一、配置getters属性 当我们想对VueX中的state中的数据进行处理&#xff0c;我们就可以使用getter配置项。 就像是组件中的数据和计算属性之间的关系。 const getters { 属性名 (state) { return 处理结果; } } 我们能够直接拿到state进行操作&#xff0c;并返回操作结果。 …

LeetCode——数组 移除元素(Java)

移除元素 简介[简单] 27. 移除元素[简单] 26. 删除有序数组中的重复项[简单] 283. 移动零[简单] 844. 比较含退格的字符串[简单] 977. 有序数组的平方 简介 记录一下自己刷题的历程以及代码。写题过程中参考了 代码随想录。会附上一些个人的思路&#xff0c;如果有错误&#x…

红黑树——插入底层实现【C++】面试重灾区!!

目录 前言 一&#xff0c;概念 定义 二&#xff0c;insert 情况一&#xff1a; 情况二&#xff1a; 情况三&#xff1a; insert代码 三&#xff0c; 红黑树验证(面试题) 产生随机数验证 每日一图区&#xff1a; 前言 AVL树是一棵绝对平衡的二叉搜索树&#xff0c;其…

IM 系统通信系统是什么

IM&#xff08;Instant Messaging&#xff09;系统是一种实时通信系统&#xff0c;允许用户通过互联网或内部网络即时发送文本消息、文件、音频、视频和其他类型的数据给其他用户或群组。这类系统通常支持在线状态显示、消息确认、消息历史记录和多端同步等功能&#xff0c;以提…

WEB3 在 React搭建的Dapp中通过redux全局获取并存储用户ETH与自定义token与交易所存储数量

上文 web3 在React dapp中全局管理web3当前登录用户/智能合约等信息中 我们简单操作&#xff0c;将web3的公共信息都存在了window对象上 然后 我们先来启动一下环境 终端输入 ganache -d打开项目 终端输入 truffle migrate --reset在区块链上发布一下智能合约 然后 我们在…

FedAT:分层机制更新的联邦学习

文章链接&#xff1a;FedAT: A Communication-Efficient Federated Learning Method with Asynchronous Tiers under Non-IID Data 发表会议: SC’21 (International Conference for High Performance Computing, Networking, Storage, and Analysis) 高性能计算&#xff0c;体…

Redis安装与常用命令

目录 一、Reids简介 二、Redis安装 2.1 Linux安装 2.2 Windows安装 三、Redis常用命令 3.1 Redis字符串 3.2 Redis哈希(Hash) 3.3 Redis列表&#xff08;List&#xff09; 3.4 Redis集合&#xff08;Set&#xff09; 一、Reids简介 Redis&#xff08;Remote Dictiona…

11.Z-Stack协议栈使用

f8wConfig.cfg文件 选择信道、设置PAN ID 选择信道 #define DEFAULT_CHANLIST 0x00000800 DEFAULT_CHANLIST 表明Zigbee模块要工作的网络&#xff0c;当有多个信道参数值进行或操作之后&#xff0c;把结果作为 DEFAULT_CHANLIST值 对于路由器、终端、协调器的意义&#xff1…

【Linux网络】Linux网络抓包工具tcpdump

一、tcpdump介绍 tcpdump 是一个Linux的网络抓包工具。它允许用户拦截和显示发送或收到过网络连接到该计算机的TCP/IP和其他数据包。tcpdump 适用于大多数的类Unix系统操作系统(如linux,BSD等)。 二、安装&用法说明 1&#xff09;安装 $ yum -y install tcpdump2&#…

【知网检索征稿】第九届社会科学与经济发展国际学术会议 (ICSSED 2024)

第九届社会科学与经济发展国际学术会议 (ICSSED 2024) 2024 9th International Conference on Social Sciences and Economic Development 第九届社会科学与经济发展国际学术会议(ICSSED 2024)定于2024年3月22-24日在中国北京隆重举行。会议主要围绕社会科学与经济发展等研究…

Everything结合内网穿透搭建在线资料库,一秒实现随时随地访问

Everythingcpolar搭建在线资料库&#xff0c;实现随时随地访问 文章目录 Everythingcpolar搭建在线资料库&#xff0c;实现随时随地访问前言1.软件安装完成后&#xff0c;打开Everything2.登录cpolar官网 设置空白数据隧道3.将空白数据隧道与本地Everything软件结合起来总结 前…

(免费领源码)Java#MYSQL在线学习平台09650-计算机毕业设计项目选题推荐

目 录 摘要 1 绪论 1.1 选题背景及意义 1.2国内外现状分析 1.3论文结构与章节安排 2 在线学习平台系统分析 2.1 可行性分析 2.2 系统业务流程分析 2.3 系统功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 系统用例分析 2.5本章小结 3 在线学习平台总体设计 …

nginx 常用优化配置项教程

本文目录 跨域配置 动静分离 反向代理-负载均衡 配置SLL证书 资源压缩 缓存机制 IP黑白名单 防盗链 大文件传输优化 跨域问题 产生原因 产生跨域问题的主要原因就在于 「同源策略」 &#xff0c;为了保证用户信息安全&#xff0c;防止恶意网站窃取数据&#xff0c;…

每日一题 2103. 环和杆 (简单)

简单题&#xff0c;直接统计就行 class Solution:def countPoints(self, rings: str) -> int:n len(rings) // 2cnt [[0, 0, 0] for _ in range(10)]for i in range(0, 2*n, 2):if rings[i] "R":cnt[int(rings[i 1])][0] 1if rings[i] "G":cnt[i…

阿里云多款ECS产品全面升级 性能最多提升40%

“阿里云始终围绕‘稳定、安全、性能、成本、弹性’的目标不断创新&#xff0c;为客户创造业务价值。”10月31日&#xff0c;杭州云栖大会上&#xff0c;阿里云弹性计算计算产品线负责人张献涛表示&#xff0c;通过持续的产品和技术创新&#xff0c;阿里云发布了HPC优化实例等多…

conda命令克隆(复制)环境方法及问题解决

背景&#xff1a;与同事进行工作交接&#xff0c;在服务器上想直接拷贝他的环境过来&#xff0c;直接复制anaconda3/envs里的环境包过来后续安装包的时候由于路径是原来的路径会安装到对方环境里&#xff0c;因此使用conda命令来进行环境克隆。 &#xff08;Linux/服务器中&am…

【广州华锐互动】有机化合物结构3D虚拟展示帮助学生更好地理解和掌握复杂化学知识

随着科技的发展&#xff0c;我们的学习方式正在发生深刻的变化。其中&#xff0c;有机化合物结构3D虚拟展示作为一种新兴的教学方式&#xff0c;正在逐渐被广泛接受和应用。这种新型的展示方式对于提高学生的学习效率&#xff0c;增强学习体验&#xff0c;以及推动化学教育的发…