SQL 相关子查询 和 不相关子查询、Exists 、Not Exists、 多表连接(包含自连接)
不相关子查询
子查询的查询条件不依赖于父查询,称不相关子查询。子查询可以单独运行的
select stu_id,sex,age
from student t
where sex=(select sexfrom studentwhere stu_id='10023'
)
相关子查询 ==== 关联子查询
子查询的查询条件依赖于父查询,称为 相关子查询。子查询不能单独运行的
子查询 也称 内部查询
父查询 也称 外部查询
如果子查询的执行依赖于外部查询,通常情况下都是因为子查询中的表用到了外部的表,并进行了条件关联,因此每执行一次外部查询,子查询都要重新计算一次,这样的子查询就称为 关联子查询
首先,从父查询中取出table1表的一个元组outer,将元组outer的expr2值传递给子查询。
然后,执行子查询,得到某个值,用这个值代替 子查询的结果 ,父查询由 嵌套查询 变为 只有一层外层查询的简单的查询。
最后,执行这个简单的查询,即得结果。
- 相关 vs 不相关
相关子查询 的查询过程 就像 高级语言的 双重For循环一样,先执行一次外层循环,然后执行内层循环完毕后,继续执行外层循环的下一个值。
不相关子查询 就是先一次性把 内层查询 执行,再 执行外层 查询。
在select 语句中,除了 group by和 limit 之前,其他的位置都可以声明 子查询
Exists 、Not Exists
select col1,col2,…
from table1 outer
where Exists (
select col1,col2
from table2
where expr1=outer.expr2
);
关联子查询通常会和EXISTS操作符一起使用,用来检查在子查询中是否存在满足条件的行。
如果在子查询中不存在满足条件的行
1、条件返回False
2、继续在子查询中查找
3、若最终子查询都没查到,则主查询的记录 就舍弃了
如果在子查询中存在满足条件的行
1、不在子查询中继续查找
2、条件返回True
3、主查询的记录会被保留
NOT EXISTS 关键字 表示 如果不存在某种条件,则返回True,否则返回False
通常 多表查询 比 子查询效率更高一些,
数据搜索引擎 如果子查询能转换城成多表查询,会自动转换。
相关文章:
![](https://img-blog.csdnimg.cn/1d41e699e4f64e37be3d3fe618515a63.png)
SQL 相关子查询 和 不相关子查询、Exists 、Not Exists、 多表连接(包含自连接)
不相关子查询 子查询的查询条件不依赖于父查询,称不相关子查询。子查询可以单独运行的 select stu_id,sex,age from student t where sex(select sexfrom studentwhere stu_id10023 )相关子查询 关联子查询 子查询的查询条件依赖于父查询,称为 相关子…...
![](https://www.ngui.cc/images/no-images.jpg)
项目规范 编写规范(范例)
项目目录 目录接口参考 项目目录结构设计,增加部分领域模型后缀强制定义,方便统一编码风格。 controller:请求处理 RestController module:按大业务区分,对多个业务对象数据聚合处理 Component manager:…...
![](https://img-blog.csdnimg.cn/55927975aa6443f38c273d91a1b5d230.png)
MongoDB数据库操作及操作命令
目录 一、基础概念 二、安装mongod 三、命令交互数据库 (1)数据库命令 (2)集合命令 (3)文档命令 四、Mongoose (1)增加一条数据 (2)插入多个数据 &am…...
![](https://www.ngui.cc/images/no-images.jpg)
Linux命令(62)之tee
linux命令之tee 1.tee介绍 linux命令tee于读取标准输入的数据,并将内容输出为文件 2.tee用法 tee [参数] [filename] tee参数 参数说明-a读取标准输入的数据,并将内容追加到文件,而非覆盖-i忽略中断信号 3.实例 3.1.将ls -l输出内容作为…...
![](https://img-blog.csdnimg.cn/aea707916bb746dbbd4721fee1004861.png)
搭建Repo服务器
1 安装repo 参考:清华大学开源软件镜像站:Git Repo 镜像使用帮助 2 创建manifest仓库 2.1 创建仓库 git init --bare manifest.git2.2 创建default.xml文件 default.xml文件内容: <?xml version"1.0" encoding"UTF-8" ?…...
![](https://img-blog.csdnimg.cn/d1c35da5db104aa194cfb685a9183a65.jpeg)
安卓:MMKV——键值存储库
目录 一、MMKV介绍 1.特点和优势: 2.使用指南: 3.依赖包: 二、MMKV的常用方法 1、初始化和获取实例: 2、存储数据: 3、读取数据 4、删除数据 5、其他操作: 三、MMKV的使用例子 MainActivityÿ…...
![](https://img-blog.csdnimg.cn/97f7c53ee7d44e3790aafac9137e35d1.png)
使用Python将图像转换为PDF:一次性解决您的批量转换需求
导语: 在数字化时代,我们经常需要处理大量的图像文件。将这些图像转换为PDF格式可以方便地存档、分享和打印。本文将介绍如何使用Python编程语言将图像批量转换为PDF,并提供了一个简单易用的图形界面来跟踪转换进度。 准备工作 在开始之前…...
![](https://img-blog.csdnimg.cn/3b4825bc10d543de921d9b00a0419905.png)
Vue——webpack
webpack 一、Install1.全局安装2.局部安装 二、总结1.打包2.定义脚本3.配置文件定义(webpack.config.js)4.项目重新加载依赖5.webpack打包Css6.style-loader 一、Install 1.全局安装 npm install webpack webpack-cli -g2.局部安装 以项目为单位,一个项…...
![](https://img-blog.csdnimg.cn/6cdd7c5a2a9941619e238c5a14eb1f88.png)
springboot房地产管理java购房租房二手房j客户sp源代码mysql
本项目为前几天收费帮学妹做的一个项目,Java EE JSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。 一、项目描述 springboot房地产管理 系统1权限:管理员 …...
![](https://www.ngui.cc/images/no-images.jpg)
Gartner 发布影响数据科学和机器学习未来方向重要趋势
出品 | CSDN 云计算 供稿 | Gartner Gartner今日发布了影响数据科学与机器学习(DSML)未来方向的重要趋势。随着DSML行业的快速发展和演变,数据对于人工智能(AI)开发与运用的重要性日益提高,尤其是投资重点…...
![](https://www.ngui.cc/images/no-images.jpg)
72. 编辑距离
题目介绍 给你两个单词 word1 和 word2, 请返回将 word1 转换成 word2 所使用的最少操作数 。 你可以对一个单词进行如下三种操作: 插入一个字符删除一个字符替换一个字符 示例 1: 输入:word1 "horse", word2 &q…...
![](https://www.ngui.cc/images/no-images.jpg)
Android12.0 原生系统SystemUI下拉状态栏和通知栏视图之锁屏通知布局
1.前言 在12.0的系统rom定制化开发中,对于系统原生systemui的锁屏界面的功能也是非常重要的,所以在锁屏页面布局中,也是有通知栏布局的,所以接下来对于息屏亮屏 通知栏布局的相关流程分析,看下亮屏后锁屏页面做了哪些功能 2.原生系统SystemUI下拉状态栏和通知栏视图之锁…...
![](https://img-blog.csdnimg.cn/e3d4e1c053354e6687a6ed8d756b4f6a.png)
周末在家值班,解决几个月前遗忘的Bug
问题: 周末被迫在家值班,无聊之际打开尘封已久的Bug清单,发现有Bug拖了几个月还没解决… 场景是这样子的,有个功能是拿Redis缓存热点数据进行展示,暂且称它为功能A,有个另外的功能B,它会去更新缓…...
![](https://www.ngui.cc/images/no-images.jpg)
Shell编程基础(十五)文本三剑客(sed)
文本三剑客(sed) 使用场景基本语法实例命令列表 使用场景 sed提供了一种面交互的方式修改文件内容。 它是一行一行处理,可以通过正则匹配要修改的部分 基本语法 基本语法 sed [-opt] command files(多个文件 空格隔开) sed 使用正则 sed -…...
![](https://img-blog.csdnimg.cn/62bddca65de24380a55f94a4e753c89b.png)
5,二叉树【p6-p7】
二叉树 5.1二叉树5.1.1例1:用递归和非递归两种方式实现二叉树的先序、中序、后序遍历5.1.1.1递归序的先序、中序、后序遍历先序遍历:中序遍历:后序遍历: 5.1.1.2非递归序的先序、中序、后序遍历先序遍历:中序遍历&…...
![](https://img-blog.csdnimg.cn/4cd83fe8357249759da89ed48a550405.png)
【Spring】如果你需要使用重试机制,请使用Spring官方的Spring Retry
文章目录 前言Spring Retry的基本使用第一步,引入Spring Retry的jar包第二步,构建一个RetryTemplate类第三步,使用RETRY_TEMPLATE注意事项 拓展方法降级操作重试策略:时间策略重试策略:指定异常策略 前言 Spring Retr…...
![](https://www.ngui.cc/images/no-images.jpg)
pagehelper 优化自定义分页和排序位置
pagehelper开源地址 https://github.com/pagehelper/Mybatis-PageHelper 1.手写Count查询优化 源码分页count时首先是判断是否存在手写的 {业务查询id}_COUNT 的查询count统计 private Long count(Executor executor, MappedStatement ms, Object parameter,RowBounds rowBound…...
![](https://www.ngui.cc/images/no-images.jpg)
Linux下查询文件夹中文件数量的方法
一、前言 在Linux系统中,我们经常需要查询文件夹中包含多少文件。本文将介绍三种在Linux中查询文件夹中文件数量的方法,帮助你轻松获取所需信息。 二、方法 1、使用ls命令和wc命令 使用ls命令的-l选项和管道操作符|结合wc命令来统计文件数量…...
![](https://img-blog.csdnimg.cn/img_convert/baf657c8d28fab8a018a3d687cb9074c.jpeg)
PS透明屏,在科技展示中,有哪些优点展示?
PS透明屏是一种新型的显示技术,它将传统的显示屏幕与透明材料相结合,使得屏幕能够同时显示图像和透过屏幕看到背后的物体。 这种技术在商业展示、广告宣传、产品展示等领域有着广泛的应用前景。 PS透明屏的工作原理是利用透明材料的特性,通…...
![](https://www.ngui.cc/images/no-images.jpg)
Hbase-面试题
1. Hbase-region切分 自动切分,默认情况下 2.0版本,第一次region的数据达到256M,会进行切分,以后就是每达到10G切分一次,切分完成后,会进行负载均衡,均衡到其他regionserver预分区自定义rowke…...
![](https://img-blog.csdnimg.cn/593c5b7c421f4e338561911b5458538e.png)
图的宽度优先深度优先遍历
图常见的遍历方式有两种,一种是宽度优先遍历,一种是深度优先遍历。 宽度优先遍历 宽度优先遍历和之前介绍的二叉树的层级遍历类似,主要也是利用Queue来完成层级的遍历,除此之外,因为图中很可能有环,所以还…...
![](https://www.ngui.cc/images/no-images.jpg)
redis Set类型命令
Redis中的Set是一种无序、不重复的集合数据结构,它提供了一系列的操作命令用于对Set进行添加、删除和查找等操作。以下是Redis中Set类型常见的一些命令: SADD key member [member …]:将一个或多个成员添加到指定的集合中。 示例:…...
![](https://img-blog.csdnimg.cn/da99e79627664d6ebcac6683a7026447.png)
Netty框架自带类DefaultEventExecutorGroup的作用,用来做业务的并发
一、DefaultEventExecutorGroup的用途 DefaultEventExecutorGroup 是 Netty 框架中的一个类,用于管理和调度事件处理器(EventExecutor)的组。在 Netty 中,事件处理是通过多线程来完成的,EventExecutor 是处理事件的基…...
![](https://img-blog.csdnimg.cn/6ddb4715ce634c5bb74ba33c0bf0588c.png)
TCP的四次挥手与TCP状态转换
文章目录 四次挥手场景步骤TCP状态转换 四次挥手场景 TCP客户端与服务器断开连接的时候,在程序中使用close()函数,会使用TCP协议四次挥手。 客户端和服务端都可以主动发起。 因TCP连接时候是双向的,所以断开的时候也是双向的。 步骤 三次…...
![](https://img-blog.csdnimg.cn/f7a89d814cae4fb4be841c34dcef9a3a.png)
【网络编程】实现一个简单多线程版本TCP服务器(附源码)
TCP多线程 🌵预备知识🎄 Accept函数🌲字节序转换函数🌳listen函数 🌴代码🌱Log.hpp🌿Makefile☘️TCPClient.cc🍀TCPServer.cc🎍 util.hpp 🌵预备知识 &…...
![](https://www.ngui.cc/images/no-images.jpg)
centos离线部署docker
有些内部环境需要离线部署,以下做一些备忘。 环境:centos7.9 准备文件: docker-20.10.9.tgz,下载地址 https://download.docker.com/linux/static/stable/x86_64/docker.service,内容见下文daemon.json,内…...
![](https://img-blog.csdnimg.cn/img_convert/edbe886599a1c07385847a169dc67809.png)
ffmpeg使用滤镜对视频进行处理播放
一、前言 在现代的多媒体处理中,视频和音频滤镜起着至关重要的作用。可以帮助开发者对视频和音频进行各种处理,如色彩校正、尺寸调整、去噪、特效添加等。而FFmpeg作为一个功能强大的开源多媒体框架,提供了丰富的滤镜库,使我们能够轻松地对多媒体文件进行处理和转换。 本…...
![](https://www.ngui.cc/images/no-images.jpg)
Ansible Handlers模块详解,深入理解Ansible Handlers 自动化中的关键组件
深入理解Ansible Handlers 自动化中的关键组件 在现代的IT环境中,自动化已经成为提高效率和减少错误的关键。Ansible作为一款流行的自动化工具,通过使用Playbooks来定义和执行任务。而Handlers作为Ansible的组件之一,在自动化过程中发挥着重要…...
![](https://img-blog.csdnimg.cn/img_convert/92c86ff9421949a9c7d1fd796aa623dc.png)
threejs点击模型实现模型边缘高亮的选中效果--更改后提高帧率
先来个效果图 之前写的那个稍微有点问题,帧率只有30,参照官方代码修改后,帧率可以达到50了,在不全屏的状态下,帧率60 1.首先需要导入库 // 用于模型边缘高亮 import { EffectComposer } from "three/examples/js…...
![](https://img-blog.csdnimg.cn/img_convert/963afe559914449221e78482ec7d474a.png)
RocketMQ 主备自动切换模式部署
目录 主备自动切换模式部署 Controller 部署 Controller 嵌入 NameServer 部署 Controller 独立部署 Broker 部署 兼容性 升级注意事项 主备自动切换模式部署 该文档主要介绍如何部署支持自动主从切换的 RocketMQ 集群,其架构如上图所示ÿ…...
![](http://www.microsoft.com/library/gallery/templates/MNP2.Common/images/arrow_px_up.gif)
某集团中英文双语网站源码/定制网站+域名+企业邮箱
ASP.NET 中的正则表达式发布日期: 8/17/2004| 更新日期: 8/17/2004速成课程Steven A. Smith适用范围:Microsoft .NET FrameworkMicrosoft ASP.NET正则表达式 API摘要:正则表达式是一种处理文本的有用工具。无论是验证用户输入、搜…...
![](/images/no-images.jpg)
站外推广网站/广告接单有什么平台
这篇文章主要为大家详细介绍了php与java通过socket通信的简单示例,具有一定的参考价值,可以用来参考一下。感兴趣的小伙伴,下面一起跟随512笔记的小玲来看看吧!demo实现的简单功能是,接受PHP端写入的字符串,…...
![](https://img-blog.csdnimg.cn/20191128115742850.png)
网站链接结构有哪些/百度营消 营销推广
文章目录一,脚本报错类:1)路由类参考:2)入参类报错参考二,脚本中的各种乱码情况处理 1)响应数据中的乱码2)响应数据中\u格式处理3)CSV导入中文乱码4)post bod…...
![](/images/no-images.jpg)
专注聊城做网站的公司/青岛网站快速排名提升
<?xml version"1.0"?><configuration> <system.web> </system.web> <system.webServer> <handlers> <!-- 此目录下的所有文件受保护,不能下载,不能执行脚本--> <clear /&…...
崇明专业网站建设/爱战网关键词
前言 在前几篇文章中我们介绍过了AbstractAssignAnalyzer.visitIf(JCIf),该方法是用来判断在if语句中变量的初始化情况的.例如如下代码: public void assgin(){int c;int a 0;if(c ! 0){} }在IDE 中会提示 The local variable c may not have been initialized,那么它是如何…...
![](https://img-blog.csdnimg.cn/6498270e2abe4b34ab0e09a4b5f78245.gif#pic_center)
wordpress 自定义结构 分类/推广费用一般多少
文章目录一.FPGA简介相关名词解释硬件资源FPGA开发流程二.编写一个简单的流水灯项目Quartus软件介绍:新建工程编写Verilog HDL文件查看RTL级门电路仿真测试硬件测试三.总结一.FPGA 简介 FPGA(Field Programmable Gate Array)是在PAL &#x…...