MySQL 高级查询

news2024/11/15 12:20:17

目录

  • 1.左关联
  • 2.右关联
  • 3.子查询
  • 4.联合查询
  • 5.分组查询

1.左关联

MySQL中的左关联(Left Join)是一种基于共同列的连接操作,
它将左侧表中的所有行与右侧表中匹配的行结合在一起,
如果右侧表中没有匹配的行,则结果集中右侧表中的所有列将显示为NULL。
左侧表是指在关键字LEFT JOIN中出现在关键字左侧的表。

下面是一个使用MySQL的LEFT JOIN进行连接操作的简单示例:

假设我们有两个表,一个是学校表(school),包含学校的ID和名称:

另一个是年级表(grade),包含年级的ID、学校ID和年级名称:

编程目标:我们可以使用以下代码来获取所有学校及其年级信息

SELECT school.school_name as "学校名称", grade.grade_name as "年级名称"
FROM 
school LEFT JOIN grade ON school.id = grade.school_id;

运行结果:

这将返回一个结果集,其中包含所有学校及其年级信息,
如果学校没有年级,则年级名称将显示为NULL。
左关联操作确保我们可以获取所有学校的信息,即使它们没有年级数据。

2.右关联

MySQL中的右关联(Right Join)是一种基于共同列的连接操作,
它将右侧表中的所有行与左侧表中匹配的行结合在一起,
如果左侧表中没有匹配的行,则结果集中左侧表中的所有列将显示为NULL。

右侧表是指在关键字RIGHT JOIN中出现在关键字右侧的表。

右关联与左关联的区别在于哪个表是主表和次要表,
即右关联的主表是右侧表,次要表是左侧表,
而左关联的主表是左侧表,次要表是右侧表。

假设有两个表,一个是学校表(school),包含学校的ID和名称,

另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

编程目标:我们可以使用以下代码来获取所有学校及其年级信息:

select school.school_name as "学校名称", grade.grade_name as "年级名称"
from 
school right join grade
on school.id = grade.school_id;

运行结果:

这将返回一个结果集,其中包含所有年级及其所属学校信息,
如果年级没有对应的学校信息,则学校名称将显示为NULL。

右关联操作确保我们可以获取所有年级的信息,即使它们没有对应的学校数据。

注意:右关联和左关联的区别在于哪个表是主表和次要表,即
右关联的主表是年级表,次要表是学校表,
而左关联的主表是学校表,次要表是年级表。

3.子查询

MySQL中的子查询(Subquery)是一种在SELECT语句中使用的嵌套查询,用于从另一个查询的结果集中检索数据。子查询可以用作WHERE或HAVING语句中的条件,或者用作SELECT语句中的列。子查询可以返回单个值、一列值或一组行。

现在,我们假设有两个表,
一个是学校表(school),包含学校的ID和名称,
另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

编程目标:以下是一个使用子查询的示例,用于检索包含特定年级名称的学校列表:

SELECT school_name
FROM school
WHERE id IN (
  SELECT school_id
  FROM grade
  WHERE grade_name = '三年级'
);

运行结果:

这将返回一个结果集,其中包含所有包含名为"三年级"的年级的学校的名称。
子查询用于获取包含特定年级的学校ID,
主查询用于从学校表中检索对应的学校名称。

另一个示例是使用子查询和聚合函数检索每个学校的年级数。
例如,以下查询使用子查询和COUNT函数从"年级表"中获取每个学校的年级数,
并将其与"学校表"中的学校名称一起返回:

SELECT school.school_name, 
  (SELECT COUNT(*) 
   FROM grade 
   WHERE grade.school_id = school.school_id) as grade_count
FROM school;

运行结果:

这将返回一个结果集,
其中包含每个学校的名称和年级数。

子查询在内部查询中使用COUNT函数从年级表中检索与学校ID匹配的行数。

主查询用于从学校表中检索学校名称,并将子查询返回的年级数作为附加列一起返回。

4.联合查询

MySQL中的联合查询(UNION)用于将多个SELECT语句的结果组合成一个结果集。
每个SELECT语句必须具有相同的列数和相似的数据类型,
而联合查询将自动对结果进行排序和去重。
可以使用UNION ALL来保留重复的行。

假设有两个表,一个是学校表(school),包含学校的ID和名称,
另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

以下是一个使用UNION查询的示例,用于检索所有学校的名称和所有年级的名称,这些学校和年级存储在不同的表中:

SELECT school_name FROM school
UNION
SELECT grade_name FROM grade;

运行结果:

这将返回一个结果集,其中包含所有学校的名称和所有年级的名称。UNION操作将自动对结果集进行去重,并按名称排序。

如果要将学校和年级的名称分开,可以使用别名将两个SELECT语句的结果列重命名:

SELECT school_name, NULL AS grade_name FROM school
UNION
SELECT NULL AS school_name, grade_name FROM grade;

运行结果:

这将返回一个结果集,其中包含学校名称和年级名称的两个列。

注意,由于两个表中的名称列位于不同的位置,因此必须使用NULL作为占位符,以确保SELECT语句中的列数相同。

5.分组查询

MySQL中的分组查询(GROUP BY)用于将查询结果按照一个或多个列进行分组,并对每个分组应用聚合函数。GROUP BY子句必须跟在SELECT语句之后,并指定要分组的列名称。

假设有两个表,一个是学校表(school),包含学校的ID和名称,
另一个是年级表(grade),包含年级的ID、学校ID和年级名称。

以下是一个使用分组查询的示例,用于检索每个学校的年级数:

SELECT school_name, COUNT(g.id) AS grade_count
FROM
school s LEFT JOIN grade g ON s.id = g.school_id
GROUP BY s.id;

运行结果:

这将返回一个结果集,其中包含每个学校的名称和年级数。

在这个查询中,使用LEFT JOIN将两个表连接起来,并使用GROUP BY子句按学校ID分组。

注意,在GROUP BY子句中使用了学校表的ID列,而不是名称列。
使用COUNT函数计算每个学校的年级数。

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

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

相关文章

[数据库]基本数据类型

●🧑个人主页:你帅你先说. ●📃欢迎点赞👍关注💡收藏💖 ●📖既选择了远方,便只顾风雨兼程。 ●🤟欢迎大家有问题随时私信我! ●🧐版权:本文由[你帅…

nodejs下载安装以及配置全局变量

一、下载 官网下载: 1、https://nodejs.org/dist/v10.16.3/node-v10.16.3-win-x64.zip 2、http://nodejs.cn/download/ 注:根据自己的项目对应电的nodejs版本去下载对应的,否则肯出现项目无法运行的情况 二、安装 无脑下一步即可&#xff0…

【2021/反事实/POI推荐】Improving location recommendation with urban knowledge graph

文章全文首发:码农的科研笔记(公众号) 原文:https://arxiv.org/abs/2111.01013 1 动机 位置推荐定义为推荐地理位置给用户,现有推荐无法无法很好的建模地理位置属性,这导致推荐结果是次优的。同时作者希望…

引入QQ邮箱发送验证码进行安全校验

最近想给自己的项目在注册时加点安全校验,本想着使用短信验证码,奈何囊中羞涩只能退而求次改用QQ邮箱验证注册~ 一.需求分析 场景:用户输入自己的邮箱,点击获取验证码,后台会发送一封邮件到对应邮箱中。 分析&#x…

element表单搜索框与表格高度自适应

一般在后台管理系统中,表单搜索框和表格的搭配是非常常见的,如下所示: 在该图中,搜索框有五个,分为了两行排列。但根据大多数的UI标准,搜索框默认只显示一行,多余的需要进行隐藏。此时的页面被…

【Flutter入门到进阶】跨平台相关-Flutter的选择

1.回顾Android渲染机制工作流程 1.1 图例 1.2 说明 1.Android内部自己通过skia引起完成图像构建 2.Android通过surfacefilinger来完成图像与驱动之间的处理 2 自建渲染引擎渲染方案 自建渲染引擎渲染方案,是有别于Web渲染采用WebView容器进行渲染UI、原生渲染…

软件设计(十)--计算机系统知识

软件设计(九)https://blog.csdn.net/ke1ying/article/details/128990035 一、效验码 奇偶效验:是一种最简单的效验方法。基本思想是:通过在编码中增加一个效验位来使编码中1的个数为奇数(奇效验)或者为偶…

微内核架构

QNX微内核架构 设计原则 最小化内核功能 将操作系统功能移到用户态,成为Server“服务”。在用户模块之间,通过消息传递机制通信。 在宏内核中,文件系统和磁盘驱动都是运行在内核态,应用通过内核调用文件系统,文件系…

Ubuntu搭建博客typecho

提示 见过这样类型的blog吧,现在就是最详细的搭建过程。 第一步 搭建apache2环境 安装命令 sudo apt -y install apache2 apache2-utils访问项目地址: /var/www/html配置文件在: /etc/apache2/日志在: /var/log/apache2/ 修改配置文件 vim…

如何在项目中正确使用异常?

文章目录异常系列文章一、异常介绍二、异常体系三、异常处理机制四、异常处理五、异常调用链异常系列文章 如何在项目中正确使用异常?如何优雅的设计Java异常Java统一异常处理–实战篇Java 异常处理的误区和经验总结你要的Java常见异常都在这里Java中异常抛出后代码…

SpringBoot后端接口请求参数映射方式详解

在SpringBoot项目中,前端HTTP请求中的参数如何映射到Controller层的接口方法中的参数?这里针对各种方式做一个测试与总结。 1:QueryString方式 QueryString参数传递的方式为,在请求URL中直接拼接请求参数如:URL?para…

Java实现调用ChatGPT详解

Java调用ChatGPT的小插件1. 申请ChatGPT账号2. 配置阶段2.1 依赖引入2.2 配置application.yml文件2.3 EnableChatGPT注解3. 使用4. 测试1. 申请ChatGPT账号 CSDN上面有很多申请ChatGPT账号的教程,可以直接搜索chatgpt账号注册,然后按照高赞的几个回答注…

谷粒商城--SPU和SKU

目录 1.SPU和SKU概念 2.表的关系理解 3.导入前端代码 4.完善后端接口 5.属性分组详情 6.规格参数详情 7. 销售属性详情 8.分组与属性关联 9.发布商品 10.仓库服务 1.SPU和SKU概念 SPU:standard product unit(标准化产品单元):是商品信息聚合的…

链表OJ(一)

目录 从尾到头打印链表_牛客题霸_牛客网 160. 相交链表 141. 环形链表 142. 环形链表 II 138. 复制带随机指针的链表 从尾到头打印链表_牛客题霸_牛客网 输入一个链表的头节点,按链表从尾到头的顺序返回每个节点的值(用数组返回)。 如输入…

Three.js中的3D文字效果

对于一些设计网页中经常会出现一些3D的文字效果,本文将利用Three.js实现各种动画WebGL文本输入效果。 示例效果 原文章 文本采样 通常情况下,文本网格是2D的平面形状,我们所要实现的3D文本形状则是要在2D的平面下,再生成z值形成…

Oracle数据库启停命令

在日常工作中,关于数据库的启停:   先关闭上层应用服务 --> 关闭监听 --> 关闭数据库;   启动数据库 --> 启动监听 --> 启动应用(Oracle SQL Developer)。 监听lsnrctl Oracle监听命令。 lsnrctl start [listener-name]&a…

Xml格式化与高亮显示

具体请参考:Xml格式化与高亮显示

分布式系统的数据一致性方案

1、在出现一致性问题时如果系统的并发或不一致情况较少,可以先使用重试来解决 a、同步重试 b、异步重试 c、入库,定时任务重试 2、分布式事务 基于数据库 XA 协议的 2PC、3PC,基于业务层的TCC,基于消息队列消息表的最终一致性方案&#xff0…

七大设计原则之接口隔离原则应用

目录1 接口隔离原则介绍2 接口隔离原则应用1 接口隔离原则介绍 接口隔离原则(Interface Segregation Principle, ISP)是指用多个专门的接口,而不使用单一的总接口,客户端不应该依赖它不需要的接口。这个原则指导我们在设计接口时…