子查询+「EXISTS」 以及 组合查询UNION ALL

news2024/9/22 15:37:32

目录

  • 方便的子查询及EXISTS
    • 使用子查询作为计算手段
    • 使用子查询过滤数据(IN)
    • 使用子查询过滤数据(EXISTS)
  • 组合查询UNION ALL
    • 如何使用UNION ALL合并多个结果集
    • 如何使用UNION去除集合的重复记录
    • 如何合并2个以上的结果集?

方便的子查询及EXISTS

使用子查询作为计算手段

比如:如何同时查询出学生编号、学生姓名、老师编号、老师姓名?

SELECT student_name, student_id, teacher_id,
(
	SELECT teacher_name FROM teacher b
	WHERE b.teacher_id = a.teacher_id
) AS teacherName
FROM student a;

注意: 子查询 里边不可返回多条查询记录,否则会直接报错。
上边查询后的数据如下:
请添加图片描述

使用子查询过滤数据(IN)

如何获取姓牛的老师教了哪些学生?

备注:老师表中有 teacher_name, teacher_id。 学生表中有 teacher_id 和老师表关联

代码:

SELECT * FROM teacher WHERE teacher_name LIKE '牛%';
SELECT student_id,student_name FROM student WHERE teacher_id IN ('T0010','T0011');

优化代码:

SELECT student_id, student_name FROM student
WHERE teacher_id IN 
(
	SELECT teacher_id FROM teacher WHERE teacher_name LIKE '牛%'
);

前伸「后边会学 表关联用法」

SELECT student_id, student_name FROM student a
INNER JOIN teacher b ON 
a.teacher_id = b.teacher_id AND teacher_name LIKE '牛%';

查询后的数据如下:
请添加图片描述

使用子查询过滤数据(EXISTS)

通过 exists实现 获取姓牛的老师教了哪些学生?

SELECT student_id, student_name FROM student a
WHERE EXISTS ( 
			SELECT 1 FROM teacher b
			WHERE a.teacher_id = b.teacher_id
			AND b.teacher_name LIKE '牛%'
			);

如何获取除姓牛的老师之外的其他老师教了哪些学生?

SELECT student_id, student_name FROM student a
WHERE NOT EXISTS ( 
				SELECT 1 FROM teacher b
				WHERE a.teacher_id = b.teacher_id
				AND b.teacher_name LIKE '牛%'
				);

组合查询UNION ALL

请添加图片描述

如何使用UNION ALL合并多个结果集

如何同时查询出年龄为10岁或一年级一班的所有学生?

SELECT * FROM student WHERE age = 10; --查询出 14 条记录
SELECT * FROM student WHERE class_id = ‘G0101’; --查询出 12 条记录

==>
SELECT * FROM student WHERE age = 10 OR class_id = ‘G0101’; --查询出 24 条记录

说明是 去重了。

使用 union all 试一试:

# 查询出 26 条记录。 
SELECT * FROM student WHERE age = 10
UNION ALL
SELECT * FROM student WHERE class_id = 'G0101'; 

如何使用UNION去除集合的重复记录

# 查询出 24 条记录。
SELECT * FROM student WHERE age = 10
UNION
SELECT * FROM student WHERE class_id = 'G0101';

如何合并2个以上的结果集?

如何同时查询出年龄为10岁或一年级一班或性别为男的所有学生?

SELECT * FROM student WHERE age = 10
UNION
SELECT * FROM student WHERE class_id = 'G0101'
UNION
SELECT * FROM student WHERE gender = '男';

如何同时查询出所有的学生编号、学生姓名和老师编号、老师姓名?
来源于不同的表

SELECT student_id,student_name FROM student
UNION
SELECT teacher_id,teacher_name FROM teacher;
  1. 待合并的结果集的字段数量必须一致。
  2. 合并后的结果集的title与第一个结果集保持一致。
  3. 待合并的结果集的字段顺序、字段类型的大类及字段值的含义尽量保持一 致。

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

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

相关文章

Hudi(6):Hudi集成Spark之spark-shell 方式

目录 0. 相关文章链接 1. 启动 spark-shell 2. 插入数据 3. 查询数据 3.1. 转换成DF 3.2. 查询 3.3. 时间旅行查询 4. 更新数据 5. 增量查询 5.1. 重新加载数据 5.2. 获取指定beginTime 5.3. 创建增量查询的表 5.4. 查询增量表 6. 指定时间点查询 7. 删除数据 …

Python学习基础笔记六十二——反射2

1、 isinstanace(obj, cls) # 检查是否obj是否是类cls的对象: class Foo(object):passobj Foo()print(isinstance(obj, Foo)) 结果返回:True。 issubclass(sub, super) # 检查sub类是否是 super 类的派生类 class Foo(object):passclass Bar(F…

python详解(5)——类,类,还是类

目录 🏆一、前言 🏆二、类 🚩1、面向对象到底是什么 🚩2、数据成员and访问,汉堡店大升级(超难) 👍①、类变量(超难) 👍②、实例变量 &#x1f6a9…

A Latent Transformer for Disentangled Face Editing in Images and Videos翻译

点击下载论文 代码地址 图1 我们将真实图像投影到StyleGAN生成器的潜空间,并在编码的潜码上实现连续的解纠缠属性编辑。从原始图像和投影图像中,我们可以连续编辑一系列属性,例如:“微笑”、“刘海”、“拱形眉毛”、“年龄”、…

分布式对象存储设计原理

保存像图片、音视频这类大文件就是对象存储。不仅有很好的大文件读写性能,还可通过水平扩展实现近乎无限容量,并兼顾服务高可用、数据高可靠。 对象存储“全能”,主要因,对象存储是原生分布式存储系统,相对于MySQL、R…

[Linux]yum安装工具和vim编辑器

🥁作者: 华丞臧. 📕​​​​专栏:【LINUX】 各位读者老爷如果觉得博主写的不错,请诸位多多支持(点赞收藏关注)。如果有错误的地方,欢迎在评论区指出。 推荐一款刷题网站 👉 LeetCode刷题网站 文…

每日一问-ChapGPT-20230101-关于新年的规划

文章目录每日一问-ChapGPT系列起因每日一问-ChapGPT-20230101-关于新年的规划优秀的人,新年之初做哪些规划疫情时代,如何更好的保护好自己有哪些运动可以提升抵抗力冥想的具体实现步骤为什么制定了年度规划但往往完成不了如何克服看手机刷视频的习惯当日…

聊聊八卦,当年的顶流明星事件是如何把公司的缓存架构“击垮”的?

V-xin:ruyuan0330 获得600页原创精品文章汇总PDF 目录 一、为什么要用缓存集群二、20万用户同时访问一个热点缓存的问题三、基于流式计算技术的缓存热点自动发现四、动加载为JVM本地缓存五、限流熔断保护六、总结 一、为什么要用缓存集群 这篇文章,咱…

数值优化之基本概念

本文ppt来自深蓝学院《机器人中的数值优化》 目录 1 推荐书单 2 优化问题的基本范式 3 数值优化在机器人领域的应用 1 推荐书单 对于英语阅读有困难的同学可以看第一本书,对于最优化的介绍也是比较详细的。 这是第一本书的ppt链接最优化:建模、算法…

【LDF】线性判别函数(三)

松弛方法 学习准则 在感知函数准则中, 目标函数中采用了 −aTy-\mathbf{a}^T \mathbf{y}−aTy 的形式。实际上有很多其它准则也可以用于感知函数的学习。线性准则 Jp(a)∑y∈Y(−aTy)J_p(\mathbf{a})\sum_{\mathbf{y} \in Y}\left(-\mathbf{a}^T \mathbf{y}\right) Jp​(a)y∈…

MP中定义全局常量用于xml的判断

1.普通方式 mybatis-plus.configuration.variables.secretFilterSwitch0 yml的方式 mybatis: mapper-locations: classpath:mapper/*.xml type-aliases-package: com.demo configuration: variables: userId: 456132465 userName: 李四 配置完成后在代码…

NLP论文RoFormer(含源码)中文解读:具有旋转式位置嵌入的增强型transformer模型(一场相对革命)

目录 1、论文与源码2、摘要介绍3、展开解读3.1、匹配或超过了目前可用于将位置信息注入变换器的所有其他方法3.2、模型思想3.3、公式推导3.4、源码解释GPT-NeoX(PyTorch)网状变压器 JAX (JAX)4、 对比实验参考文献1、论文与源码 RoFormer匹配或超过了目前可用于将位置信息注…

分享76个PHP源码,总有一款适合您

链接:https://pan.baidu.com/s/1dC6_-CLs_qSyNnKEmno0Pg?pwd6666 提取码:6666 下面是文件的名字,我放了一些图片,文章里不是所有的图主要是放不下...,大家下载后可以看到。 UTForum社区论坛 v2.5 响应式健身房信息展…

小波分析—— 3. 实现一个简单的Haar小波

由于小波在应用形式上与卷积很相似,所以如果你有需要,可以查看我以前写过的内容: 信号采样基本概念 —— 冲激函数卷积计算——1. 关于卷积的基本概念卷积计算——2. 一些常用于图像的卷积核与应用 另外常见的信号处理工具,傅里…

Unity脚本(三)

视频教程:https://www.bilibili.com/video/BV12s411g7gU?p128 目录 Time Prefab Animation Time Time.time:自应用程序启动以来,每帧的开始时间(只读) Time.deltaTime:每帧间隔,或说完…

SpringData

文档:D:\springdata SpringData是一个用来简化dao层开发的框架.在保证了各个底层存储特性同时,提供了一套统一的数据访问API.它可以很好的支持常用的关系型数据库和非关系型数据库. 使用SpringData做为dao层开发技术,将大大简化代码,而且其API比各个技…

【力扣周赛#326】6279.数组乘积中的不同质因数数目+6196.将字符串分割成值不超过K的子字符串+6280.范围内最接近的两个质数

目录 6278.统计能整除数字的位数 - 简单ac 6279.数组乘积中的不同质因数数目 - 质因数 6196.将字符串分割成值不超过K的子字符串 - 贪心 6280.范围内最接近的两个质数 - 质数筛 贪心 6278.统计能整除数字的位数 - 简单ac 6278. 统计能整除数字的位数 class Solution {pu…

aws codebuild 配置codecommit更新触发和squid正向代理

本文主要讨论如何通过监听codecommit仓库自动触发codebuild的构建,以及为codebuild配置正向代理 通过codecommit更新触发codebuild codecommit触发器相关 每个codecommit最多配置10个触发器 sns触发器 为sns创建lambda函数订阅,在lambda日志中查看s…

一个例题,了解包装类

下列代码输出什么,为什么? public class Test3 {public static void main(String[] args) {Integer a1 100;Integer a2 Integer.valueOf(100);Integer a3 new Integer(100);System.out.println(a1 a2);System.out.println(a1 a3);System.out.println(a1.equals(a3));Sys…

分离编译、类型萃取、变参模板

分离编译 一个程序由若干个源文件共同实现,每个源文件单独编译生成目标文件,最后将所有的目标文件链接起来形成单一可执行文件的过程称之为分离编译模式。模板不支持分离编译 编译器报的这种错误属于链接性错误,也就是当程序预处理、编译、汇…