MySQL查询—联合查询、子查询

关于表格的创建,请看上一篇文章——MySQL查询—连接查询

1、联合查询:把多次查询的结果合并,形成一共新的查询集。

UNION,UNION ALL

语法:

SELECT 字段列表 FROM 表A... 
UNION [ALL]
SELECT 字段列表 FROM 表b... 

1.1、举个例子

1.1.2、将薪资低于5000的员工,和年龄大于50岁的员工全部查询出来

SELECT * FROM emp_new a WHERE a.salary<5000 
UNION ALL 
SELECT * FROM emp_new b WHERE b.age>50;

查询结果发现将薪资低于5000,年龄大一50的员工都展示出来了,但是会发现没有去重,鹿仗客出现了两次,所以我们要进行去重的操作,删除all即可

SELECT * FROM emp_new a WHERE a.salary<5000 
UNION  
SELECT * FROM emp_new b WHERE b.age>50;

总结:上下字段数目必须一致,UNION ALL会有城府结果,UNION不会 联合查询比使用or的效率更高,不会索引失效

2、子查询

SQL语句中嵌套SELECT语句,称作嵌套查询,又称子查询。子查询外边缘的语句可以是INSERT/UPDATE/DELETE/SELECT

语法:

SELECT * FROM t1 WHERE comulumn1=(SELECT comulumn1 FROM t2)

子查询又分为4类:标量子查询、列子查询、行子查询、表子查询

2.1、标量子查询(子查询结果为单个值)

子查询返回的结果是单个值(数字、字符串、日期等)。常用操作符-<,>,<=,>=

2.1.1、查询“销售部”的所有员工信息(当然有好多解决方法哈)

a、查询“销售部”部门id

SELECT id FROM dept where name="销售部";

b、根据销售部门id,查询员工信息 

SELECT * FROM emp_new where dept_id=4;

那么可以直接将两个语句进行合并 

SELECT *FROM dept where dept= (SELECT id from dept where name ="销售部");

2.2、列子查询(子查询结果为一列)

列子查询的结果是一列(可以是多行)

列子查询——常用操作符
操作符描述
IN在指定的集合范围内,多选一
NOT IN不在指定的集合范围内
ANY子查询返回列表中,有任意一共满足即可
SOME与ANY等同,使用SOME的地方都可以是ANY
ALL子查询返回列表的所有值都必须满足

2.2.1、查询销售部和市场部的所有员工信息

#SELECT id FROM dept b where b.`name`='销售部' OR b.`name`='市场部';SELECT * FROM emp_new WHERE dept_id IN (SELECT id FROM dept b where b.`name`='销售部' OR b.`name`='市场部');

2.2.2、查询比财务部所有人工资都高的员工信息 

#SELECT id FROM dept b WHERE b.`name`='财务部';
#SELECT salary FROM emp_new a WHERE a.dept_id=(SELECT id FROM dept b WHERE b.`name`='财务部');
SELECT *FROM emp_new a WHERE a.salary>ALL(SELECT salary FROM emp_new a WHERE a.dept_id=(SELECT id FROM dept b WHERE b.`name`='财务部'));

2.2.3、 查询比研发部任意一人工资高的员工信息(ANY或SOME)

#SELECT id FROM dept b WHERE b.`name`='研发部';
#SELECT salary FROM emp_new a WHERE a.dept_id=(SELECT id FROM dept b WHERE b.`name`='研发部');
SELECT *FROM emp_new a WHERE a.salary>ANY(SELECT salary FROM emp_new a WHERE a.dept_id=(SELECT id FROM dept b WHERE b.`name`='研发部'));

2.3、行子查询(子查询结果为一行)

行子查询的结果是一行(可以是多列)

举个例子:

2.3.1、查询与张无忌的薪资及直属领导相同的员工

#SELECT id FROM emp_new a WHERE a.`name`='张无忌';
#SELECT a.salary,a.managerid FROM emp_new a WHERE id=(SELECT id FROM emp_new a WHERE a.`name`='张无忌');
SELECT * FROM emp_new a WHERE (a.salary,a.managerid)=(SELECT a.salary,a.managerid FROM emp_new a WHERE id=(SELECT id FROM emp_new a WHERE a.`name`='张无忌'));
SELECT * FROM emp_new  WHERE (salary,managerid)=(SELECT salary,managerid FROM emp_new WHERE name='张无忌'));

2.4、表子查询(子查询结果为多行多列)

表子查询返回的结果是多行多列 常用操作符是IN

举个例子:

2.4.1、查询与“鹿仗客”,“宋远桥”的职位和薪资相同的员工信息

#SELECT job,salary FROM emp_new WHERE name='鹿杖客' or name='宋远桥';
SELECT * FROM emp_new WHERE (job,salary) IN (SELECT job, salary FROM emp_new WHERE name='鹿仗客' OR name='宋远桥');

2.4.2、查询入职日期是2006-01-01之后的员工,及其部门信息

#SELECT * FROM emp_new a where a.enterdate>'2006-01-01';SELECT e.*,d.* FROM (SELECT * FROM emp_new a where a.enterdate>'2006-01-01') e LEFT JOIN dept d ON e.dept_id=d.id; 

 完结撒花

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

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

相关文章

qt-C++笔记之使用信号和槽实现跨类成员变量同步响应

qt-C笔记之使用信号和槽实现跨类成员变量同步响应 —— 杭州 2024-01-24 code review! 文章目录 qt-C笔记之使用信号和槽实现跨类成员变量同步响应1.运行2.main.cpp3.test.pro4.编译 1.运行 2.main.cpp 代码 #include <QCoreApplication> #include <QObject> #…

Linux下Docker搭建部署Typecho博客【详细版】

Linux下Docker搭建部署Typecho博客【详细版】 一、环境准备1.1.准备阿里云服务器【新用户免费使用三个月】1.2.准备远程工具【FinalShell】1.3.系统信息1.4.安装所需软件包1.5.设置docker镜像源1.6.更新yum软件包索引1.7.确认停用selinux 二、安装Docker2.1.安装Docker-Ce2.2.查…

【RTP】webrtc 学习3: webrtc对h264的rtp解包

rtp_rtcp\source\video_rtp_depacketizer_h264.cc【RTP】webrtc 学习2: webrtc对h264的rtp打包 中分析了打包过程的代码,这样再来看解析过程的源码就容易多了:本代码主要基于m79,m98类似。这里注明了jitterbuffer 会再次 做 解析stap-a 变为NAL units解析ParseFuaNalu 第一…

ACL、VLAN、NAT笔记

一、ACL ---访问控制列表 1.ACL的作用 1&#xff0c;访问控制&#xff1a;在路由器流量流入或流出的接口上&#xff0c;匹配流量&#xff0c;然后 执行设定好的动作。 ---- permit 允许 , deny 拒绝 2&#xff0c;抓取感兴趣流&#xff1a;ACL可以和其他服务结合使用。ACL只…

MyBatis 如何整合 Druid 连接池?

Mybatis 如何整合 Druid 数据连接池呢&#xff1f;首先打开创建的 Maven 工程&#xff0c;找到 pom.xml 文件&#xff0c;添加 Druid 依赖。 <!--druid连接池--> <dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId&…

【C语言】数组的应用:三子棋游戏

由于代码较长&#xff0c;为了增加可读性&#xff0c;我们把代码分别写到game.h&#xff0c;game.c&#xff0c;test.c&#xff0c;里面&#xff0c;其中game.h用来声明函数&#xff0c;实现函数功能的代码在game.c&#xff0c;测试游戏的代码在test.c 为了方便后续的更改&…

ThreadLocal学习笔记

ThreadLocal类图 ThreadLocal/InheritableThreadLocal/ \TransmittableThreadLocal(阿里巴巴) TransmissibleThreadLocal(阿里巴巴)ThreadLocal 这是Thread类的局部变量&#xff0c;每个线程私有。 它主要用于解决多线程中的数据共享问题&#xff0c;保…

k8s 版本发布与回滚

一、实验环境准备&#xff1a; kubectl get pods -o wide kubectl get nodes -o wide kubectl get svc 准备两个nginx镜像&#xff0c;版本号一个是V3&#xff0c;一个是V4 二、准备一个nginx.yaml文件 apiVersion: apps/v1 kind: Deployment metadata:name: nginx-deploylab…

翻译: GPT-4 Vision静态图表转换为动态数据可视化 升级Streamlit 三

GPT-4 Vision 系列: 翻译: GPT-4 with Vision 升级 Streamlit 应用程序的 7 种方式一翻译: GPT-4 with Vision 升级 Streamlit 应用程序的 7 种方式二 1. 将任何静态图表转换为动态数据可视化 ChatGPT Vision 不仅可以将涂鸦变成功能齐全的 Streamlit 应用程序&#xff0c;还…

SpringBoot整合nacos的入门Demo

Nacos介绍 Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service的首字母简称&#xff0c;一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集&#xff0c;帮助您快速…

操作系统(6)----线程相关

目录 1.线程与进程的关系 2.线程的属性 3.线程的实现方式 用户级线程 内核级线程 多线程模型 一对一模型: 多对一模型&#xff1a; 多对多模型&#xff1a; 4.线程的状态和转换 5.线程的组织与控制 1.线程与进程的关系 可以把线程理解为“轻量级进程”。线程是一个…

大创项目推荐 题目:基于卷积神经网络的手写字符识别 - 深度学习

文章目录 0 前言1 简介2 LeNet-5 模型的介绍2.1 结构解析2.2 C1层2.3 S2层S2层和C3层连接 2.4 F6与C5层 3 写数字识别算法模型的构建3.1 输入层设计3.2 激活函数的选取3.3 卷积层设计3.4 降采样层3.5 输出层设计 4 网络模型的总体结构5 部分实现代码6 在线手写识别7 最后 0 前言…

【Spring实战】31 Spring Boot3 集成 Gateway 微服务网关

文章目录 1. 定义2. 功能3. 示例代码1) 创建一个业务服务2&#xff09;创建一个网关服务3&#xff09;启动服务4&#xff09;验证 4. 代码参考结语 1. 定义 Spring Cloud Gateway 是一个基于 Spring Framework 的开源网关服务&#xff0c;用于构建微服务架构中的 API 网关。它…

C51 单片机学习(一):基础外设

参考 51单片机入门教程 1. 单片机简介 1.1 定义 单片机&#xff08;Micro Controller Unit&#xff0c;简称 MCU&#xff09; 内部集成了 CPU、RAM、ROM、定时器、中断系统、通讯接口等一系列电脑的常用硬件功能单片机的任务是信息采集&#xff08;依靠传感器&#xff09;、处…

休息日的思考与额外题——链表

文章目录 前言链表知识点 一、 92. 反转链表 II二、21. 合并两个有序链表总结 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招&#xff0c;计划二刷完卡子哥的刷题计划&#xff0c;加油&#xff01; 二刷决定精刷了&#xff0c;于是参加了卡子哥的刷题班&#xff0c;训练…

富文本编辑器CKEditor4简单使用-01

富文本编辑器CKEditor4简单使用-01 1. 快速体验入门1.1 通过从 CDN 加载 CKEditor 来快速体验1.2 从官方网站下载软件包1.2.1 官网下载1.2.2 解压、简单使用&#xff08;自带index页面示例&#xff09;1.2.3 将 CKEditor 4 添加到自己的页面1.2.3.1 目录结构1.2.3.2 效果1.2.3.…

TensorFlow2实战-系列教程6:迁移学习实战

&#x1f9e1;&#x1f49b;&#x1f49a;TensorFlow2实战-系列教程 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Jupyter Notebook中进行 本篇文章配套的代码资源已经上传 1、迁移学习 用已经训练好模型的权重参数当做自己任务的模型权重初始化一般全连接层需…

【机器学习】工程实践问题概述

机器学习实际应用时的工程问题与面临的挑战 一、实现细节问题 1.1 训练样本 训练样本与标注对各类机器学习算法和模型的精度影响 训练样本的选择对各类机器学习算法和模型的影响 训练样本的优化 如何进行数据增强&#xff1f; 如何进行数据清洗&#xff1f; 样本的标注对各类机…

数据结构(二)------单链表

制作不易&#xff0c;三连支持一下呗&#xff01;&#xff01;&#xff01; 文章目录 前言一.什么是链表二.链表的分类三.单链表的实现总结 前言 上一节&#xff0c;我们介绍了顺序表的实现与一些经典算法。 但是顺序表这个数据结构依然有不少缺陷&#xff1a; 1.顺序表指定…

导航页配置服务Dashy本地部署并实现公网远程访问

文章目录 简介1. 安装Dashy2. 安装cpolar3.配置公网访问地址4. 固定域名访问 简介 Dashy 是一个开源的自托管的导航页配置服务&#xff0c;具有易于使用的可视化编辑器、状态检查、小工具和主题等功能。你可以将自己常用的一些网站聚合起来放在一起&#xff0c;形成自己的导航…