[mysql]子查询的概述和分类及单行子查询

news2025/1/7 18:37:32

子查询引入

查询的基本结构已经给大家了,子查询里面也是有一些新的内容,子查询其实就是在查询中嵌套另一个查询,叫嵌套查询可能大家更容易理解一点..,类似与FOR循环和FOR循环的嵌套,这一章是我们查询的最难的部分,大家

难度是查询的顶峰,多表查询和子查询是非常重要,SQL优化里面主要还是针对查询的优化.

子查询是mysql4.1里面引入的,现在java用的比较多的是8.0,数据库和java企业都没有动力去更新,我们讲课的向下兼容的,虽然现在是8.0,但是讲的还是会涉及,当我们现在有一个需求,查询谁的工资比a高,所以我们要先查询abel的工资,然后再把这个工资放入查询条件中进行查询.

首先我们看到了这个需求,谁的工资比abel高,我们如何不用子查询来进行.

SELECT last_name,salary

FROM employees

WHERE last_name=’abel’

我们可以看到abel工资的11000,我们现在就查询工资比11000高就行.

我们要和数据库服务器进行2次交互,效率肯定是比较低的,我们就像能不能用一条语句来进行.我们是不是可以用自连接来进行

SELECT T1.last_name,T1.salary

FROM employees T1

JOIN employees T2

ON T1.salary>T2.salary AND T2.last_name='abel'

这时我们利用自连接,把所有工资比abel高的字段筛选出来.

方式2自连接肯定要比方式1块

1虽然这个条件可以用多表查询,但是其他类似的条件就不能用自连接

2:这个不容易想出来,不够直观

那么我们就可以引入子查询

子查询介绍

我们先写WHERE条件,因为这个条件不是一个值,我们需要用另一个查询才能查询出来,所以我们直接把查询条件改成另一个查询结构SELECT last_name,salary

FROM employees

WHERE salary>(

              SELECT salary

              FROM employees

              WHERE last_name='abel')

注意这里的查询条件只能出现一个值.由一个问题需求引入一个查询

首先我们谈谈一个名称,一个称谓,子查询包括了外查询,和内查询.

外面的查询就叫外查询,里面的就叫内查询,这是相对的叫法.

外查询也被叫做主查询,内查询也被叫子查询.

接下来我们看看有什么具体的要求,

1子查询是在主查询之前一次查询,

2子查询的结果被外查询使用

注意事项

1:子查询要被括号包裹,由于子查询比较复杂,用括号包裹会比较清晰

2子查询要放在比较条件的右侧

Ps,就是在比较符号的后面,如果在前面就是这样

SELECT last_name,salary

FROM employees

WHERE (

              SELECT salary

              FROM employees

              WHERE last_name='abel')<salary

我们会发现这样也行,但是为什么要这样呢,我们这是为了可读性和美观的考虑.头短尾长比较好.

3.单行操作费对应单行子查询,多行操作符对应多行子查询.

子查询分类

分类可以从不同的角度去分,第一个角度,

角度1: 出多个结果或者一个结

单行子查询,,

查询之后出一个结果的就是单行子查询

多行子查询

查询之后出多个结果的就是单行子查询

角度2内查询是否被执行多次

相关查询:

比如我们需要查询部门工资大于本部门平均工资的员工信息

里面的子查询会因为外查询记录部门的不同返回的值而改变.也就是返回不同的平均值.

比如白和白生的就是黑的,

不相关查询

比如需求我们要查询工资大于公司的平均工资的员工.

里面的子查询,或者说内查询条件,不会跟随外查询记录的改变而改变,

这里的就说清楚了,因为我们的子查询语句比较多,所以要写的行数也比较多,所以我们先做一个分类,我们下面要讲的就是单行子查询和多行子查询的案例.

我会把这两个查询的范围都限制在不相关子查询内容,所以下面的相关子查询把这个难度就调高起来

趁热打铁开始吧

也就是里面只有一个数据供我们外部使用,

子查询的编写技巧:

1从里往外写

2从外往里写

单行子查询

单行子查询操作符号

= != > < <> <= >=

也就是我们之前的逻辑操作符号

情况1

”查询工资大于149号员工工资的员工信息

由于我们不知道149号员工的工资,我们就要进行子查询.”

这里因为比较简单,所以我们技巧1和技巧2都可以

我们就先写子查询

        SELECT employee_id

        FROM employees

        WHERE employee_id=149

再写外查询

没问题,我们就查询出来了

题目2返回job_id与141号员工相同,salary比143员工多的员工姓名

SELECT employee_id,job_id,salary

FROM employees

WHERE job_id=(

        SELECT job_id

        FROM employees

        WHERE employee_id=141)

AND salary>(

        SELECT salary

        FROM employees

        WHERE employee_id=143)

如果我们看见了一个查询语句,我们可以把这个语句转换为中文吗,也就是要看出这个查询语句来看出它的需求.这个能力也要有,我们现在主要是做需求.

题目返回公司工资最少的员工last_name,job_id和salary

SELECT last_name,job_id,salary

FROM employees

WHERE salary=(

        SELECT MIN(salary)

        FROM employees)

注意这里可能是好几个员工,但是还是单行子查询,因为我们内查询只返回一条记录

情况2

查询与141号员工的manager_id和department_id相同的其他员工的employee_id,manager_id,department_id

我们先不用理过滤条件,查询其他员工的

employee_id,manager_id,department_id还是会写的把,我们就先写外查询

SELECT employee_id,manager_id,department_id

FROM employees

WHERE

然后补充内查询

SELECT employee_id,manager_id,department_id

FROM employees

WHERE manager_id =(

              SELECT manager_id

              FROM employees

              WHERE employee_id=141)

AND department_id =(

              SELECT department_id

              FROM employees

              WHERE employee_id=141)

这是方式1:

方式1成对子查询

我们还有一个方式2,可以一次性把两个字段条件写在一起

SELECT employee_id,manager_id,department_id

FROM employees

WHERE (manager_id,department_id) =(

              SELECT manager_id,department_id

              FROM employees

              WHERE employee_id=141)

结果是一致的,这叫我们的成对子查询.效率上差别不大,上面的适用性比较高,所以这个不会写也没事,了解就可以了.适用场景太窄了

情况3,HAVING中的子查询

题目:查询最低工资大于50号部门最低工资的 部门id和其最低工资

SELECT MIN(salary)

SELECT department_id,MIN(salary)

FROM employees

GROUP BY department_id

HAVING MIN(salary)>(

                    SELECT MIN(salary)

                    FROM employees

                    WHERE department_id=50)

因为五十号部门工资是不确定的,所以我们要用到子查询

这里不行要空值我们就可以用外查询WHERE筛选掉

SELECT department_id,MIN(salary)

FROM employees

WHERE department_id IS NOT NULL

GROUP BY department_id

HAVING MIN(salary)>(

                    SELECT MIN(salary)

                    FROM employees

                    WHERE department_id=50)

所以我们HAVING中我们也可以使用子查询

情况4:CASE中的子查询

显示员工的employee_id,last_name和location.其中若员工department_id与location_id为1800的department_id相同则location为canada,其余为USA

这里我们还是先写外查询再写内查询,

SELECT employee_id,last_name,(

  CASE department_id

                                         WHEN (

        SELECT department_id

        FROM departments

        JOIN locations T3

        ON T3.location_id=departments.location_id

        WHERE T3.location_id=1800)

 THEN

                                          'canada'

                                         ELSE

                                          'USA'

END

) "location"

FROM employees

情况5:子查询中的空值问题.

如果子查询的结果是空值,那么不会报错,返回的会是一个空表比如下面这种情况

SELECT last_name,job_id

FROM employees

WHERE job_id=(SELECT job_id FROM employees WHERE last_name=102)

情况6:非法使用子查询

如果我们用单行操作符进行多行操作,会出现什么情况

这时会直接报错

下期介绍

如果多行子查询我们就应该用多行操作符号,IN或者BETWEEN.

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

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

相关文章

EDA --软件开发之路

之前一直在一家做数据处理的公司&#xff0c;从事c开发&#xff0c;公司业务稳定&#xff0c;项目有忙有闲&#xff0c;时而看下c&#xff0c;数据库&#xff0c;linux相关书籍&#xff0c;后面跳槽到了家eda公司&#xff0c;开始了一段eda开发之路。 eda 是 electric design …

【移动应用开发】使用多媒体--通知/播放音频/视频

目录 一、具体步骤 二、运行截图 1. 开启通知权限 2. 播放音乐 3. 播放视频 三、源代码 1. activity_main.xml 2. activity_video_player.xml 3. activity_notification.xml 4. 一些配置 5. MainActivity 6. VideoPlayerActivity 7. NotificationActivity 8. And…

代码备份管理 —— Git实用操作

目 录 Git那些事版本控制系统git环境搭建运行bashbash命令行git账号全局设置本地仓库的存在远程仓库的存在git管理基本流程git仓库的文件夹常用git命令工作区变为git仓库add命令使用branch命令使用checkout命令使用commit命令使用仓库状态查询代码变更后提交删除或恢复文件管理…

windows下安装及使用labelme

1.进入Anaconda Prompt对话窗口 输入&#xff1a;conda create --namelabelme python3.6 # 创建一个叫labelme的环境 conda create --namelabelme python3.6 2.激活新建的环境&#xff0c;进入 输入&#xff1a;activate labelme #激活环境 activate labelme 3.安装pyqt5 …

集群渲染是一台节点输出吗?它是云渲染农场吗

集群渲染并非单一节点的输出&#xff0c;而是一种分布式计算技术&#xff0c;它通过多台计算机协同工作来加速3D渲染过程。这种技术常被视作云渲染农场的前身&#xff0c;两者在提高渲染效率方面有着相似之处。接下来&#xff0c;让我们深入了解集群渲染与云渲染农场之间的联系…

建筑行业内部知识库的重要性与实施策略

在当今瞬息万变的建筑行业中&#xff0c;企业面临着前所未有的竞争挑战。为了在市场中保持竞争力&#xff0c;建筑企业不仅需要拥有先进的技术和设备&#xff0c;还必须具备高效的知识管理能力。内部知识库&#xff0c;作为知识管理的核心工具&#xff0c;正逐渐成为建筑企业提…

【Fastjson反序列化漏洞:深入了解与防范】

一、Fastjson反序列化漏洞概述 Fastjson是一款高性能的Java语言JSON处理库&#xff0c;广泛应用于Web开发、数据交换等领域。然而&#xff0c;由于fastjson在解析JSON数据时存在安全漏洞&#xff0c;攻击者可以利用该漏洞执行任意代码&#xff0c;导致严重的安全威胁。 二、F…

数据结构 —— AVL树

目录 1. AVL的概念 2.AVL树的结构 3.AVL树的插入 3.1 平衡因子更新 4. 旋转 4.1 旋转的原则 4.2 右单旋 4.2.1 右单旋代码实现 4.3 左单旋 4.3.1 左单旋代码实现 4.4 左右双旋 4.4.1 左右双旋代码实现 4.5 右左双旋 ​编辑 4.5.1 右左双旋代码实现 5. AVL树的判断…

[GXYCTF 2019]Ping Ping Ping 题解(多种解题方式)

知识点: 命令执行 linux空格绕过 反引号绕过 变量绕过 base64编码绕过 打开页面提示 "听说php可以执行系统函数&#xff1f;我来康康" 然后输入框内提示输入 bjut.edu.cn 输入之后回显信息,是ping 这个网址的信息 输入127.0.0.1 因为提示是命令…

Python小游戏16——开心消消乐

运行结果显示 代码如下 import pygame import random # 初始化pygame pygame. init() # 定义一些常量 WIDTH 600 HEIGHT 600 NUM_GRID8 GRID_SIZE WIDTH // NUM_GRID FPS 30 # 定义颜色 WHITE (255&#xff0c; 255&#xff0c;255) BLACK(0&#xff0c;0&#xff0c;0) COL…

基于树莓派的安保巡逻机器人--(一、快速人脸录入与精准人脸识别)

目录 零、前言 一、人脸检测 二、人脸识别 1、采集人脸 2、训练人脸识别模型 3、人脸识别应用 零、前言 随着智能安防需求的增长&#xff0c;基于人工智能和物联网的安保系统逐渐成为趋势。树莓派因其低成本、高扩展性等特点&#xff0c;成为很多AI项目的理想平台。本文将为大…

HTB:BoardLight[WriteUP]

目录 连接至HTB服务器并启动靶机 1.How many TCP ports are listening on BoardLight? 2.What is the domain name used by the box? 3.What is the name of the application running on a virtual host of board.htb? 4.What version of Dolibarr is running on Board…

react18中redux-saga实战系统登录功能及阻塞与非阻塞的性能优化

redux-saga中的effect常用的几个是有区分出阻塞与非阻塞的&#xff0c;这里主要看下call和fork两者的区别。 实现效果 非阻塞的task执行&#xff0c;不用等到登录成功后请求的list接口完成&#xff0c;点击退出按钮可以立即退出 阻塞task的执行&#xff0c;必须等到登录成功…

【JavaEE】【多线程】进阶知识

目录 一、常见的锁策略1.1 悲观锁 vs 乐观锁1.2 重量级锁 vs 轻量级锁1.3 挂起等待锁 vs 自旋锁1.4 普通互斥锁 vs 读写锁1.5 可重入锁 vs 不可重入锁1.6 不公平锁 vs 公平锁 二、synchronized特性2.1 synchronized的锁策略2.2 synchronized加锁过程2.3 其它优化措施 三、CAS3.…

炫酷的登录框!(附源码)

大家想看什么前端效果请留言 预览效果 源码 <!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>登录页…

RK3568平台开发系列讲解(内存篇)ioremap进行物理内存的映射

🚀返回专栏总目录 文章目录 一、使用案例:二、ioremap 函数的使用三、volatile 的使用一、使用案例: ioremapdevm_ioremap (你不用担心资源的释放)二、ioremap 函数的使用

中小企业设备资源优化:Spring Boot系统实现

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统&#xff0c;它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等&#xff0c;非常…

基于SSM(spring+springmvc+mybatis)+MySQL开发的新闻推荐系统

基于内容的新闻推荐系统 一、环境搭建 开发框架&#xff1a;SSM(springspringmvcmybatis)开发语言&#xff1a;Java、HTML5、JavaScript开发工具&#xff1a;MyEclipse软件依赖&#xff1a;tomcat8、MySQL 1.1 新建工程 打开 myeclispe&#xff0c;新建一个 maven 工程&…

STM32 HAL ADC FIR 窗函数实现低通滤波

FIR 窗函数实现低通滤波 文章目录 FIR 窗函数实现低通滤波1.窗的分类与选择2.matlab设计3.代码编写4.结果欣赏与群延迟5.其他可能报错5.1.adc采集的数据没问题&#xff0c;vofa打印成-nan5.2.vofa打印的滤波数据为初始化的0 6.代码备忘 1.窗的分类与选择 2.matlab设计 主页命令…

例程学习(学习笔记)

project括号里面表示工程的名称&#xff0c;决定了最后生成的bin文件的名称&#xff0c;比如我们现在编译后的bin文件名称就是hello_world.bin文件&#xff0c;如果改成了project(xxx)&#xff0c;编译后的名称就是xxx.bin 这个文件用来设置路径&#xff0c;咱们得例程案例里面…