【SQL 中的分组查询与联合查询详解】

文章目录

  • SQL 中的分组查询与联合查询详解
    • 1. GROUP BY分组查询
      • 1.1 语句格式
      • 1.2 示例说明
        • 1.2.1 分别查询哥哥组和弟弟组的英语成绩总和
        • 1.2.2 查询哥哥组的所有成绩总和
    • 2. 联合查询
      • 2.1 内连接
        • 2.1.1 语法格式
        • 2.1.2 执行过程
      • 2.2 外连接
        • 2.2.1 左外连接
        • 2.2.2 右外连接
      • 2.3 自连接
      • 2.4 子查询
        • 2.4.1 单行子查询
        • 2.4.2 多行子查询
      • 2.5 合并查询
        • 2.5.1 显示去重
        • 2.5.2 不显示去重
      • 2.6 一条SQL语句的执行顺序

SQL 中的分组查询与联合查询详解

在数据库操作中,GROUP BY分组查询和联合查询是非常强大且常用的功能,它们能够帮助我们从大量数据中提取有价值的信息。本文将深入探讨这两种查询方式,并结合具体示例进行详细讲解。

1. GROUP BY分组查询

1.1 语句格式

GROUP BY语句的基本格式如下:

SELECT分组列的列名,除分组列的列名之外只能使用聚合函数
FROM查询表的表名
GROUP BY分组列的列名
HAVINGHAVING子句:对GROUP BY的结果进行过滤(只能和GROUP BY一起使用)

在这个语句中,SELECT关键字用于指定要查询的列,其中除了分组列之外,其他列必须使用聚合函数(如SUMAVGCOUNT等)。FROM关键字指定要查询的表。GROUP BY关键字用于指定按照哪一列进行分组。HAVING子句则用于对分组后的结果进行进一步的筛选。

1.2 示例说明

假设有如下所示的exam表:

1.2.1 分别查询哥哥组和弟弟组的英语成绩总和
SELECTexam.`group`, SUM(exam.english)
FROMexam AS exam
GROUP BYexam.`group`

在这个查询中,我们使用GROUP BY将数据按照group列进行分组,然后使用SUM聚合函数计算每个组的英语成绩总和。执行结果如下:
在这里插入图片描述

1.2.2 查询哥哥组的所有成绩总和
SELECTexam.`group`,SUM( exam.english +exam.chinese+exam.math) 
FROMexam AS exam 
GROUP BYexam.`group` 
HAVINGexam.`group` ='哥哥组'

这里同样使用GROUP BY进行分组,不过在SUM函数中计算了每个学生的所有科目成绩总和。HAVING子句用于筛选出group哥哥组的记录。执行结果如下:
在这里插入图片描述

通过这两个示例,我们可以看到GROUP BY分组查询在对数据进行分类统计时的强大功能。它能够根据指定的列将数据分组,并对每个组的数据进行聚合计算,从而得到我们需要的统计信息。

2. 联合查询

联合查询用于将多个查询结果合并在一起,常见的联合查询包括内连接、外连接、自连接、子查询和合并查询等。下面我们将逐一介绍这些联合查询的用法。

2.1 内连接

内连接是一种最常用的连接方式,它返回两个表中满足连接条件的所有行。

2.1.1 语法格式
select * from table1,table2 where table1.xx=table2.xx;

这是一种基于逗号分隔的表名和WHERE子句指定连接条件的写法。更标准的写法是使用JOIN关键字:

SELECT *
FROM table1
JOIN table2 ON table1.xx = table2.xx;
2.1.2 执行过程

内连接的执行过程可以分为以下几个步骤:

  1. 计算笛卡尔积:首先计算参加表连接的两个表的笛卡尔积。例如,假设有qintianpeople表和qintiancommodity表,执行以下查询:
SELECT*
FROMqintianpeople,qintiancommodity

结果会得到两个表的笛卡尔积,即qintianpeople表中的每一行与qintiancommodity表中的每一行进行组合,结果集的行数为两个表行数的乘积。执行结果如下:

  1. 通过连接条件过滤无效数据:在笛卡尔积的基础上,通过连接条件过滤掉不满足条件的数据。例如:
SELECT*
FROMqintianpeople,qintiancommodity
WHEREqintianpeople.people_id = qintiancommodity.people_id

这里使用WHERE子句指定了连接条件,只有people_id相等的行才会被保留。执行结果如下:

  1. 加入查询条件得到想要的结果行:可以进一步添加查询条件来筛选出符合特定要求的行。例如:
SELECT*
FROMqintianpeople,qintiancommodity
WHEREqintianpeople.people_id = qintiancommodity.people_id ANDqintianpeople.people_id>5

这里在连接条件的基础上,添加了qintianpeople.people_id>5的条件,进一步筛选出符合条件的行。执行结果如下:

  1. 精简列名得到最终想要查询的列:最后,可以根据需求选择需要显示的列,精简结果集。例如:
SELECTqintianpeople.people_id,people_name,commodity_name
FROMqintianpeople,qintiancommodity
WHEREqintianpeople.people_id = qintiancommodity.people_id ANDqintianpeople.people_id>5

这个查询只选择了people_idpeople_namecommodity_name这几列,得到了更精简的结果。执行结果如下:

2.2 外连接

外连接分为左外连接和右外连接,它们的区别在于以哪个表为基准进行连接。

2.2.1 左外连接

语法格式

Select * from table1 left join table2 on table1.xx=table2.xx;

左外连接以左表为基准,左边的数据全部显示,右边的数据没有对应记录的显示为NULL。例如:

SELECTqintianpeople.people_id,people_name,commodity_name
FROMqintiancommodityLEFT JOINqintianpeopleON qintiancommodity.people_id = qintianpeople.people_id

执行结果如下:

2.2.2 右外连接

语法格式

Select * from table1 right join table2 on table1.xx=table2.xx;

右外连接以右表为基准,右边的数据全部显示,左边的数据没有对应记录的显示为NULL。例如:

SELECTqintianpeople.people_id,people_name,commodity_name
FROMqintiancommodityRIGHT JOINqintianpeopleON qintiancommodity.people_id = qintianpeople.people_id

执行结果如下:

2.3 自连接

自连接是指在同一个表上进行连接操作,它可以把行比较转化为列比较,在查询时可以使用WHERE进行过滤。

语法格式

select * from table1 t1,table1 t2 where t1.xx=t2.xx;

2.4 子查询

子查询是指在一个查询中嵌套另一个查询,将内层查询的结果作为外层查询的条件。子查询可以分为单行子查询和多行子查询。

2.4.1 单行子查询

语法格式

Select * from table1 where id=(select id from table2 where...);

例如,假设有customers表和orders表,我们想要查询下了订单的客户信息,可以使用如下子查询:

SELECT *
FROM customers
WHERE customer_id IN (SELECT DISTINCT customer_id FROM orders);

这个子查询先从orders表中获取所有下过订单的customer_id,然后外层查询从customers表中查询这些customer_id对应的客户信息。

2.4.2 多行子查询

语法格式

Select * from table1 where id in (select id from table2 where...);

多行子查询与单行子查询类似,不过它返回的是多个值,使用IN关键字来匹配这些值。例如:

SELECT *
FROM products
WHERE product_id IN (SELECT product_id FROM order_items WHERE quantity > 10);

这个查询会返回在order_items表中被订购数量大于10的所有产品信息。

子查询可以多次嵌套,以实现更复杂的查询逻辑。例如:

SELECT *
FROM customers
WHERE customer_id IN (SELECT customer_idFROM ordersWHERE order_date > '2023-01-01' AND customer_id IN (SELECT customer_idFROM customersWHERE region = 'Asia')
);

这个嵌套子查询首先筛选出亚洲地区的客户customer_id,然后在这些客户中筛选出在2023年1月1日之后下过订单的客户customer_id,最后查询出这些客户的详细信息。

2.5 合并查询

合并查询用于将两个或多个查询的结果合并到一个结果集中,分为去重合并和不去重合并。

2.5.1 显示去重

语法格式

select * from table1 union select * from table2;

UNION关键字会将两个查询结果合并,并去除重复的行。

2.5.2 不显示去重

语法格式

select * from table1 union all select * from table2;

UNION ALL关键字会将两个查询结果直接合并,保留所有的行,包括重复的行。

2.6 一条SQL语句的执行顺序

了解一条SQL语句的执行顺序对于编写高效准确的查询非常重要。SQL语句的执行顺序如下:

  1. FROM:指定需要查询的表。
  2. JOIN ON:取笛卡尔积并根据连接条件进行连接。
  3. WHERE:使用限制条件过滤数据。
  4. GROUP BY:对数据进行分组查询。
  5. HAVING:对分组后的结果进行过滤。
  6. SELECT:筛选需要显示的列。
  7. DISTINCT:对结果进行去重(如果有该关键字)。
  8. ORDER BY:对结果进行排序。
  9. LIMIT:限制返回的行数。

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

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

相关文章

《FMambaIR:一种基于混合状态空间模型和频域的方法用于图像恢复》学习笔记

paper:(PDF) FMambaIR: A Hybrid State Space Model and Frequency Domain for Image Restoration 目录 摘要 一、引言 二、相关工作 1、图像恢复 2、频率学习 3、状态空间模型(SSM) 三、框架 1、基本知识 2、整体框架 3、F-Mamba…

51c自动驾驶~合集47

我自己的原文哦~ https://blog.51cto.com/whaosoft/13083194 #DreamDrive 性能爆拉30%!英伟达:时空一致下的生成重建大一统新方案~ 从自车的驾驶轨迹中生成真实的视觉图像是实现自动驾驶模型可扩展训练的关键一步。基于重建的方法从log中生成3D场景…

SpringBoot项目打war包要点

1. 修改pom文件packaging 2. 不使用内置tomcat 3. 加一个类 4. 修改外部tomcat配置文件 5. 修改nginx配置文件,构建集群 资料来自网络

GMM高斯混合聚类算法(Matlab)

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 GMM高斯混合聚类算法 matlab2023b语言,一键出图,直接运行 1.代码注释清晰,自行解读容易。 2…输出图例如图所示包括:聚类图(聚类结果图),协方差矩阵类型…

华为数据中心CE系列交换机级联M-LAG配置示例

M-LAG组网简介 M-LAG(Multi-chassis Link Aggregation)技术是一种跨设备的链路聚合技术,它通过将两台交换机组成一个逻辑设备,实现链路的负载分担和故障切换,从而提高网络的可靠性和稳定性。下面给大家详细介绍如何在…

Vue2.0的安装

1.首先查看是否已经安装了node.js 选择以管理员方式打开命令提示符(权限较高),或者通过cmd的方式打开 打开后输入node -v 查看自己电脑是否安装node,以及版本号 node -v 如果没有的话,请查看Node.js的安装 2.Vue和脚…

GAN 用于图像增强

工程需求,临时学一下gan的原理和基于图像增强的实现 原理 论文链接 Generative Adversarial Nets 我们提出了一个通过对抗过程来估计生成模型的新框架,其中我们同时训练两个模型:捕获数据分布的生成模型G和估计样本来自训练数据而不是G的…

sqlfather笔记

这里简单记录写学习鱼皮sqlfather项目的笔记,以供以后学习。 运行 将前后端项目clone到本地后,修改对应配置文件运行项目。 后端 1.配置好mysql后运行这个sql文件建立对应的表。 2.修改数据库密码 3.修改完后运行启动类即可 4. 启动结果 5.查看A…

【大数据】机器学习------支持向量机(SVM)

支持向量机的基本概念和数学公式: 1. 线性可分的支持向量机 对于线性可分的数据集 ,其中(x_i \in R^d) 是特征向量 是类别标签,目标是找到一个超平面 ,使得对于所有 的样本 ,对于所有(y_i -1) 的样本,…

Android系统开发(一):AOSP 架构全解析:开源拥抱安卓未来

引言 当我们手握智能手机,流畅地滑动屏幕、切换应用、欣赏动画时,背后其实藏着一套庞大且精密的开源系统——Android AOSP(Android Open Source Project)。这套系统不仅是所有安卓设备的根基,也是系统开发者的终极 pl…

mono3d汇总

lidar坐标系 lidar坐标系可以简单归纳为标准lidar坐标系和nucense lidar坐标系&#xff0c;参考链接。这个坐标系和车辆的ego坐标系是一致的。 标准lidar坐标系 opendet3d&#xff0c;mmdetection3d和kitt都i使用了该坐标系 up z^ x front| /| /left y <------ 0kitti采…

linux下springboot项目nohup日志或tomcat日志切割处理方案

目录 1. 配置流程 2. 配置说明 其他配置选项&#xff1a; 3. 测试执行 4. 手动执行 https://juejin.cn/post/7081890486453010469 通常情况下&#xff0c;我们的springboot项目部署到linux服务器中&#xff0c;通过nohup java -jar xxx.jar &指令来进行后台运行我们…

[Python学习日记-78] 基于 TCP 的 socket 开发项目 —— 模拟 SSH 远程执行命令

[Python学习日记-78] 基于 TCP 的 socket 开发项目 —— 模拟 SSH 远程执行命令 简介 项目分析 如何执行系统命令并拿到结果 代码实现 简介 在Python学习日记-77中我们介绍了 socket 基于 TCP 和基于 UDP 的套接字&#xff0c;还实现了服务器端和客户端的通信&#xff0c;本…

使用SIPP发起媒体流性能测试详解

使用SIPP发起媒体流性能测试详解 一、SIPP工具简介二、测试前的准备三、编写测试脚本四、运行测试五、分析测试结果六、总结SIPP(SIP Performance Protocol)是一个开源工具,专门用于SIP(Session Initiation Protocol)协议的性能测试和基准测试。SIP是一种用于控制多媒体通…

macOS 安装JDK17

文章目录 前言介绍新特性下载安装1.下载完成后打开downloads 双击进行安装2.配置环境变量3.测试快速切换JDK 小结 前言 近期找开源软件&#xff0c;发现很多都已经使用JDK17springboot3 了&#xff0c;之前的JDK8已经被替换下场&#xff0c;所以今天就在本机安装了JDK17&#…

重温STM32之环境安装

缩写 CMSIS&#xff1a;common microcontroller software interface standard 1&#xff0c;keil mdk安装 链接 Keil Product Downloads 安装好后&#xff0c;开始安装平台软件支持包&#xff08;keil 5后不在默认支持所有的平台软件开发包&#xff0c;需要自行下载&#…

vue3+ts+uniapp 微信小程序(第一篇)—— 微信小程序定位授权,位置信息权限授权

文章目录 简介一、先看效果1.1 授权定位前&#xff0c;先弹出隐私协议弹框1.2 上述弹框点击同意&#xff0c;得到如下弹框1.3 点击三个点&#xff0c;然后点设置 1.4 在1.2步骤下&#xff0c;无论同意或者拒绝 二、manifest.json 文件配置三、微信公众平台配置3.1 登录进入微信…

迅为RK3568开发板篇OpenHarmony实操HDF驱动控制LED-编写内核 LED HDF 驱动程序

接下来编译 LED 驱动&#xff0c;该驱动用于在基于华为设备框架&#xff08;HDF&#xff09;的系统中控制 LED 灯的开关&#xff0c;完整代码如下所示&#xff1a; 更多内容可以关注&#xff1a;迅为RK3568开发板篇OpenHarmony

kafka集群安装Raft 协议

​使用消息中间件&#xff0c;可以实现系统与系统之间的异步通信和无缝对接&#xff0c;也可用在模块之间的的异步通信&#xff0c;有效避免了同步阻塞IO。作为一个高吞吐量、可扩展、高可靠性的分布式消息系统&#xff0c;Kafka 能够胜任从简单的消息队列到复杂的流处理平台的…

华为AI培训-NLP实验

中文分词、命名实体识别、语义词性标注、语句逻辑推理、文本摘要、机器翻译、文本情感分析、内容创作 1 实验介绍 1.1 实验背景 中文分词、命名实体识别、语义词性标注、语句逻辑推理是自然语言处理领域中的重要任务。中文分词是将连续的汉字序列切分成有意义的词语序列…