嵌套查询(一)-谓词IN、量词ANY、量词ALL

一、在多个表之间进行数据查询,除了可以使用连接查询之外,也可以使用嵌套查询,那么什么是嵌套查询呢?如何使用嵌套查询呢?

1、将一个SELECT-FROM查询,嵌套在另一个SELECT查询语句中,那么这个SELECT-FROM查询就叫嵌套查询或者子查询,被嵌套的上层查询被称为父查询,在子查询中还可以继续嵌入子查询,构成多层嵌套查询,一个查询的结果可能是一个关系,即元组的集合,也可能是一个值,即聚集函数的结果,因此,子查询既可以嵌套在其父查询的SELECT子句的目标列表达式中参与计算,也可以嵌套在其父查询的FROM子句中作为进一步查询的对象,还可以嵌套在其父查询的WHERE子句或HAVING短语的条件表达式中,作为进一步查询的条件,不同的DBMS对嵌套查询的支持程度不同

2、下面介绍几种常用的嵌套查询的使用方式

二、谓词IN实现嵌套查询

IN谓词用于判断一个值是否属于一个集合,其运算结果是一个布尔值

E 【NOT IN (V1,V2,...,Vn)

1、将子查询放在IN谓词后面的小括号中,使用子查询查询出来的结果集,实际上还是一个表

2、独立子查询:子查询的结果不依赖于父查询

(1)举例:查询选修了“003”课程的学生姓名

select sN
from s
where sNo in (select sNo from sC where cNo='003')

该查询需求也可以使用连接查询满足,但是从DBMS对SQL语句的查询语句的处理方式来看,嵌套查询语句更有利于生成优化的查询执行方案。

(2)逻辑运算符NOT的使用,举例:查询没有选修“003”课程的学生姓名

select sN
from s
where sNo not in (select sNo from sC where cNo='003')

错误实例:不可以使用连接查询

select sN
from s,sC
where s.sNo=sC.sNo and sC.cNo!='003'

原因:嫦娥不仅选修了003的课程,还选修了其它的课程

三、比较操作符实现嵌套查询

当嵌套查询的结果是一个值是,该嵌套查询可以嵌套在WHERE子句的元组条件选择表达式中

1、举例1:查询选修“003”课程的成绩高于刘备的学生的学号和成绩

use XSXK;
select sNo,grade
from sC
where cNo='003' and grade>(select gradefrom sCwhere cNo='003' and sNo in(select sNofrom swhere sN='刘备')
)

这是一个多层嵌套查询,并且每一个子查询都是一个独立子查询

2、举例2:查询每个学生所修课程成绩超过其所有选课平均成绩的学号和课程号

use XSXK;
select sC1.sNo,sC1.cNo
from sC sC1
where grade>(
select avg(sC2.grade)
from sC sC2
where sC2.sNo=sC1.sNo
)

(1)这里的子查询结果与父查询的当前元组有关,这种查询被称为相关子查询

(2)在相关子查询中,如果涉及到了父查询所用到的表,往往要对这两个表至少一个进行重命名操作,以便标识不同的元组

四、使用量词ANYALL实现嵌套查询

1、在有些DBMS中,如果子查询的结果是一个集合,还可以使用ANY或ALL与比较符配合来实现嵌套查询

2、ANY(子查询)

ANY的语义为查询结果中的某个值,当子查询结果中有某一个值满足比较运算符,比较运算结果则为真

3、ALL(子查询)

ALL的语义为查询结果中的所有值,当子查询结果中的每一个值都满足比较运算符,比较运算结果才为真。

4、举例1:查询其它院系中比数计学院某个学生年龄小的学生

select *
from s
where sD!='数计学院' and  sB > any(
select sB
from s
where sD='数计学院'
)

5、举例2:查询其它院系中比数计学院学生年龄都小的学生

select *
from s
where sD!='数计学院' and  sB > all(
select sB
from s
where sD='数计学院'
)

6、量词ANY或ALL与比较运算符配合的功能也可以用谓词IN或用聚集函数与与比较符配合来实现

(1)当子查询的结果是一个集合而不是一个值时,比较运算符前的值肯定会不等于查询结果中的某个值,那么比较运算符不能于ANY结果永真,作为父查询的条件没有意义

(2)举例1:查询其它院系中比数计学院某个学生年龄小的学生

select *
from s
where sD!='数计学院' and  sB > (
select min(sB)
from s
where sD='数计学院'
)

(3)举例2:查询其它院系中比数计学院学生年龄都小的学生

select *
from s
where sD!='数计学院' and  sB > (
select max(sB)
from s
where sD='数计学院'
)

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

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

相关文章

C语言 | 文件操作(上)【必收藏】

文件操作(上) 1、使用文件的原因2、什么是文件3、二进制文件和文本文件4、 流的打开与关闭4.1 流和标准流4.1.1 流4.1.2 标准流 4.2 文件指针4.3 文件的打开和关闭 5、文件的顺序读写5.1 顺序读写函数介绍5.1.1 fputc与fgetc 1、使用文件的原因 首先来看…

Codeforces Round 614 (Div. 1) B. Aroma‘s Search

Aroma’s Search time limit per test: 1 second memory limit per test: 256 megabytes input: standard input output: standard output With a new body, our idol Aroma White (or should we call her Kaori Minamiya?) begins to uncover her lost past through the OS s…

人工智能在肿瘤细胞分类中的应用|顶刊速递·24-06-06

小罗碎碎念 推文主题——人工智能在肿瘤细胞分类中的应用。 重点关注 临床方向的同学/老师建议重点关注第四篇&第六篇文章,最近DNA甲基化和蛋白组学与AI的结合,在顶刊中出现的频率很高,建议思考一下能否和自己的课题结合。 工科的同学重…

LeetCode题练习与总结:验证回文串--125

一、题目描述 如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。 字母和数字都属于字母数字字符。 给你一个字符串 s,如果它是 回文串 ,返回 true &#xf…

入职一周感慨

上周太忙了,去打了个球,买了个二手电动车,然后按了个spa。所以忘记吾日三省吾身了,罪孽呀。 本来事情都很顺利的,昨天在工作上,我不小心把cdh集群的主节点ntp remove了,然后重启了所有服务&…

【永久使用】Xshell7+Xftp7免费版安装教程

Xshell7是用来连接linux服务器的软件。 Xftp7是和linux服务器进行文件操作的软件(可新增,删除服务器上的文件),可嵌入在Xshell7中运行。 如何安装 先下载安装文件(免费获取) https://gitee.com/hadluo/…

网格重构技术在AI绘画中的革新作用

引言: 随着人工智能(AI)技术的飞速发展,艺术创作也迎来了前所未有的变革。AI绘画不仅改变了艺术家的创作方式,还为非专业人士开启了艺术创作的大门。在众多AI技术中,网格重构技术因其独特的作用和效果成为A…

JS实现文字溢出隐藏效果

需求场景 由于项目原因,经常需要使用到canvas来将dom生成为图片供用户保存,但canvas的css属性(例如本文实现的文字溢出隐藏效果)支持并不全面,所有有些功能只能用JS来实现了 实现思路 用JS循环判断填充文本后的元素…

为什么选择Symfony框架?深入解析PHP框架

目录 1. Symfony框架概述 1.1 什么是Symfony? 1.2 Symfony的历史 2. Symfony的核心特性 2.1 MVC架构 2.2 可重用的组件 2.3 Bundle系统 2.4 高度可配置性 2.5 强大的调试工具 3. 为什么选择Symfony框架? 3.1 性能与可扩展性 3.2 企业级应用的首选 3.3 活跃的社区…

Python NumPy 库详解

大家好,在当今数据驱动的世界中,处理大规模数据、进行复杂数值计算是科学研究、工程设计以及数据分析的关键任务之一。在Python生态系统中,NumPy(Numerical Python)库是一款备受推崇的工具,它为我们提供了高…

PHP调用快递地址解析接口助力项目优化

快递地址智能解析是日常开发中一个重要的工具,可以帮助快递公司提高效率,减少错误,进行数据分析。也可以帮助网购用户快速输入收货地址,提升用户体验。 看完以下操作文档,可以让你在开发中以最快时间完成这个功能&…

mybatis 之 DatabaseIdProvider 教程

mybatis之DatabaseIdProvider 应用中可能同时涉及到多个数据库,比如MySQL,oracle等等,那么当我们使用mybatis的时候,怎么做到动态切换呢?DatabaseIdProvider 可以帮助我们 public interface DatabaseIdProvider {def…

取消el-time-picker组件在Sarari浏览器中下拉回弹效果

在项目中用到el-time-picker组件来选择时间, 但是在Safari浏览器中,滑动分钟列表时,会取消时钟的选择,这是因为滑动分钟列表时有一个回弹效果,回弹把时钟的选择给取消掉了,我们现在要做的就是取消滑动时钟时…

谷歌配置邮箱stmp开发

谷歌的stmp开发,需要一个专用密码 首先要打开二部验证 然后再通过这个链接,创建专用密码 https://myaccount.google.com/u/6/apppasswords?gar1 然后拿专用密码去写在代码上,谷歌发邮件,不知道是不是国内还是什么原因&#xff…

Java-开发技巧

1.判断list或者map 用org.apache.commons.collections4包下的 CollectionUtils.isNotEmpty 2.判断字符串 用org.apache.commons.lang3包下的 StringUtils 3.执行分组操作&#xff0c;List<StatusDAO>不会为null情况 Map<LocalDateTime,List<StatusDAO>> …

Centos上部署Node服务和MongoDB

文章目录 1.Centos上安装运行Node服务1. 安装Node.js2.验证Node.js安装3.运行Node.js应用程序4.调试Node.js应用 2.Centos上安装MongoDB3.创建Node服务1.配置初始化文件2.创建index.js文件3.启动服务3.配置公网访问forever的引入pm2的引入 4.应对CORS跨域使用cors中间件手动设置…

深入理解MySQL分区技术

前言&#xff1a; 在数据量不断增长的当今时代&#xff0c;数据库的性能优化变得尤为重要。MySQL作为一款广泛使用的数据库管理系统&#xff0c;提供了多种性能优化手段&#xff0c;其中分区技术是提升大型表处理效率的有效方法之一。通过将数据分散到多个独立的物理子表中&am…

《大道平渊》· 拾叁 —— 失眠?忍不住乱想?不如反其道而行之!

《平渊》 拾叁 "睡觉的时候就是要胡思乱想" 声明&#xff1a;以下内容针对非失眠症人群&#xff0c;如果失眠不是偶尔发生&#xff0c;而是长期存在&#xff0c;以下内容和你无关&#xff0c;请尽早治疗&#xff0c;遵循医嘱。 失眠的本质是什么&#xff1f;心理因素…

C++并发之锁(std::lock_guard,std::unique_lock)

目录 1 概述2 使用实例3 接口使用3.1 lock_guard3.2 adopt_lock3.3 defer_lock3.4 try_to_lock3.5 try_lock3.6 release3.7 lock3.8 call_one1 概述 锁保护是通过使互斥对象始终处于锁定状态来管理互斥对象的对象。。   在构造时,互斥对象被调用线程锁定,在析构时,互斥被解…

Qt实现信号与槽,模拟Qt的信号与槽,观察者模式

运行在VS2022&#xff0c;x86&#xff0c;Debug下 33. Qt信号与槽 实现原理&#xff1a;观察者模式&#xff0c;即当一个对象被修改时&#xff0c;就会自动通知依赖它的对象。应用&#xff1a;对象间的通信。 33.1. Qt实现信号与槽&#xff0c;代码如下。 #include <QOb…