SQL备忘--集合运算

news2024/11/20 0:42:04

前言

  • 本文讨论的是两个子查询结果的合并问题, 是行维度下的合并处理

    例如子查询A查出5条记录、子查询B查出3条记录,那么将两个结果合并,则共返回8条记录

  • 行维度上要能进行合并,前置要求是:子查询的列字段是相同的,既要求数量、字段名相同,有要求类型匹配能互相兼容(可以隐式转换匹配)

交集运算(INTERSECT)

交集是取两个子查询中都存在的行数据,不存在的数据会被舍弃

演示案例:

(最后结果返回2、3)
请添加图片描述

sql案例
SELECT class_name
FROM t_class
WHERE student_num > 50			-- 查询人数超过50人的班级
INTERSECT						-- 交集合并得到满足两个条件的所有班级名称
SELECT class_name
FROM t_class_score
WHERE AVG(score) > 80			-- 查询平均分大于80分的班级名
GROUP BY class_name

交集可以改为等价的内连接查询,例如上例:

SELECT t1.class_name
FROM 
	(SELECT class_name
	FROM t_class
	WHERE student_num > 50)	 t1		-- 查询人数超过50人的班级
JOIN
	(SELECT class_name
	FROM t_class_score
	WHERE AVG(score) > 80			-- 查询平均分大于80分的班级名
	GROUP BY class_name) t2
ON t1.class_name = t2.class_name

并集运算(UNION)

并集是将两个子查询中的行数据合并相加后返回
两个子查询中共同存在的数据(交集数据),可选择在结果中只保留一份数据,还是两份都保留()

演示案例:
  1. 去重,Union [DISTINCT]
    (最后结果返回1、2、3、4)
    请添加图片描述

  2. 不去重, Union ALL
    (最后结果返回1、2、3、2、3、4, 共六个原酸)
    在这里插入图片描述

sql案例
SELECT class_name
FROM t_class
WHERE student_num > 50			-- 查询人数超过50人的班级
UNION 						    -- 并集合并得到两者的集合,查出的班级是超过50人、或者平均分大于80分的;同时满足两者条件的班级名也只保留了一个
SELECT class_name
FROM t_class_score
WHERE AVG(score) > 80			-- 查询平均分大于80分的班级名
GROUP BY class_name

并集可以改为等价的外连接查询,例如上例:

SELECT COALESCE(t1.class_name, t2.class_name)	-- 外连接会出现NULL的情况,因此用COALESCE在两个结果中选一个不为NULL的
FROM 
	(SELECT class_name
	FROM t_class
	WHERE student_num > 50)	 t1		-- 查询人数超过50人的班级
FULL JOIN
	(SELECT class_name
	FROM t_class_score
	WHERE AVG(score) > 80			-- 查询平均分大于80分的班级名
	GROUP BY class_name) t2
ON t1.class_name = t2.class_name

差集运算(Except)

用于计算子查询结果差集,返回的结果为在子查询1但不在子查询2中的数据

演示案例:

(最后结果返回1)
请添加图片描述

sql案例
SELECT class_name
FROM t_class
WHERE student_num > 50			-- 查询人数超过50人的班级
EXCEPT 						    -- 排除掉人数超过50人的班级中、平均分大于80的班级
SELECT class_name
FROM t_class_score
WHERE AVG(score) > 80			-- 查询平均分大于80分的班级名
GROUP BY class_name

MYSQL 不支持EXCEPT运算符
ORACLE 21c开始支持EXCEPT,以前使用等价的MINUS关键字

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

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

相关文章

关于你不知道的前端文件上传方式

1、原生方法 我们开发中比较常用的有使用 input 属性的 type 设置为 file,这里我们就不进行过多的阐述,已经老生常谈了。 今天我们主要介绍两个新的属性 showDirectoryPicker 和 showOpenFilePicker 这里是官方文档 1、showDirectoryPicker showDirectoryPicker方…

20240115-【UNITY 学习】第一人称移动增加斜坡移动、冲刺和蹲伏功能

直接修改或者替换PlayerMovement_01.cs using System.Collections; using System.Collections.Generic; using UnityEngine;public class PlayerMovement_02 : MonoBehaviour {private float moveSpeed; // 玩家移动速度public float walkSpeed 7; // 行走速度public float sp…

内网搭建文件服务器

文件下载地址 Releases rejetto/hfs GitHubHFS is a web file server to run on your computer. Share folders or even a single file thanks to the virtual file system. - Releases rejetto/hfshttps://github.com/rejetto/hfs/releases http://192.168.100.33/apk/ 就…

.net core IResultFilter 的 OnResultExecuted和OnResultExecuting的区别

//全局过滤器 builder.Services.AddMvc(m > { m.Filters.Add<AllResultFilter>(); }); 1、实现过滤器 public class AllResultFilter : IResultFilter {/// <summary>/// 结果执行后方法/// 不可更改结果/// </summary>/// <param name"con…

spring常见漏洞(2)

Spring Web Flow框架远程代码执行(CVE-2017-4971)漏洞&#xff0c;是由于Spring Web Flow的数据绑定问题带来的表达式注入&#xff0c;从而导致任意代码执行。 影响版本 2.4.0-2.4.4、Older unsupported versions are also affected 漏洞分析 view对象处理用户事件&#xf…

【外汇天眼】误入假冒Ctrl Investments无法出金,投资者:太相信网友了!

在当下这个互联网迅速发展的时代&#xff0c;各类交友类APP成为人们拓展社交圈的新渠道。一方面这样的交友软件在满足了用户基础的社交要求&#xff0c;另一方面网络世界所交往的朋友能给用户带来的神秘感和新鲜感&#xff0c;所以导致一部分年轻人离不开这些交友软件。然而&am…

STM32快速复制MX25L1606E系列Flash

去年做了一个使用RS485对PIC18F45K80系列单片机进行在线升级的程序&#xff0c;如果是小批量的出厂烧录程序和升级验证&#xff08;出厂前肯定要测试单片机是否能正常读写Flash&#xff09;是可以的&#xff0c;但是后来产品订单量很大&#xff0c;生产线的烧录及升级验证就很缓…

QT上位机开发(多线程处理)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 目前大部分cpu都是多核cpu&#xff0c;所以如果不用多线程进行数据处理的话&#xff0c;实在是太浪费资源了。另外&#xff0c;很多的操作都是阻塞…

数据中心温湿度监测,这个细节你真的看懂了吗?

在当今数字化和智能化的时代&#xff0c;温湿度监控系统成为了各行业中不可或缺的关键技术&#xff0c;其在维护设备、保障产品质量和确保生产环境稳定性方面发挥着至关重要的作用。 随着科技的不断进步&#xff0c;企业和机构越来越意识到对环境参数的实时监测对于提高效率、降…

采样次数与频率的关系

采样次数&#xff08;Sampling Points&#xff09; 在给定时间内记录信号值的次数。 假设在1秒内对一个连续信号采样10次&#xff0c;这意味着每0.1秒记录一次信号值。 假设在1秒内对一个连续信号采样100次&#xff0c;这意味着每0.01秒记录一次信号值。 频率&#xff08;Fre…

GitLab CI 实现项目A更新代码自动触发项目B更新错误码文档

一、CI/CD简介 CI/CD 是持续集成&#xff08;Continuous Integration&#xff09;和持续交付/持续部署&#xff08;Continuous Delivery/Continuous Deployment&#xff09;的缩写&#xff0c;是一种软件开发和交付的最佳实践。这两个概念通常一起使用&#xff0c;但有些时候它…

XCTF:Hidden-Message[WriteUP]

使用Wireshark打开文件 分析能分析的流&#xff0c;这里直接选择UDP流 分别有两段流&#xff0c;内容都是关于物理的 和flag没啥关系&#xff0c;只能从别的方面下手 分析&#xff1a;整个数据包&#xff0c;全部由UDP协议组成 其中发送IP和接收IP固定不变&#xff0c;数据长…

[python]pyside6安装和在pycharm配置

安装命令&#xff1a; pip install PySide6 -i https://mirror.baidu.com/pypi/simple Pycharm配置Pyside6 打开Pycharm点击File -> Settings -> Tools -> External Tools&#xff0c;点击&#xff0b;。需要添加 Pyside6-Designer 、 Pyside6-UIC 和 Pyside6-rcc三…

第9章 通信动力与环境

文章目录 9.1.1 动力与环境的组成9.1.2 动力与环境的特点9.1.3 动力与环境的地位与作用9.1.4 动力与环境的基本要求9.2.1 通信电源的组成和结构9.2.2 交流供电系统1、交流供电系统的组成2、市电交流供电的质量指标3、常用高压电电器4、电力变压器5、常用低压电器6、油机发电机组…

Mac电脑采样器软Native Instruments Kontakt 7

Native Instruments Kontakt 7是一款功能强大的采样器软件&#xff0c;专为音乐制作和声音设计而设计。它提供了一个直观的界面和丰富的功能&#xff0c;使用户能够轻松地加载、编辑和演奏采样样本。Kontakt 7支持多种采样格式&#xff0c;包括WAV、AIFF、 Kontakt .nki等&…

CTFhub-phpinfo

CTFhub-Web-信息泄露-“phpinfo” 题目信息 解题过程 ctrlF搜索关键字…

JMeter定时器之同步定时器

JMeter定时器之同步定时器 1. 背景2. 目的3. 介绍4. 例子4.1单个请求4.2多个请求 1. 背景 在实际生活中大家肯定遇到过一种场景&#xff0c;就是在某一时间或某一时刻&#xff0c;某件商品进行抢购&#xff0c;相当于秒杀&#xff1b;但是用JMeter进行测试的时候&#xff0c;如…

WEB前端人机交互导论实验-实训4 DIV+CSS综合运用

1.项目1 设计《中国教育网络》杂志简介 A题目要求&#xff1a; 综合运用DIVCSS设计《中国教育网络》杂志简介页面&#xff0c;效果如下图所示: B.思路 整体思路是将《中国教育网络》杂志的简介信息以有序的方式呈现出来&#xff0c;同时通过样式和布局设置&#xff0c;使页…

erlang/OTP 平台(学习笔记)(四)

Erlang语言精要 Erlang shell 相较于日常惯用的系统&#xff0c;Erlang系统是一套更富交互性的环境。使用大部分编程语言时&#xff0c;要么把程序编译成OS可执行文件后运行&#xff0c;要么用解释器来执行一堆脚本文件或编译后的字节码文件。无论哪种情况&#xff0c;都是让…

【极光系列】SpringBoot集成Mybatis

【极光系列】SpringBoot集成Mybatis 一.gitee地址 浅夏的猫 shawsongyue 直接下载可用 https://gitee.com/shawsongyue/aurora.git 二.mysql安装教程 详细参考我的另外一遍博客&#xff1a; https://blog.csdn.net/weixin_40736233/article/details/135582926?spm1001.201…