MySQL数据库11——子查询语句

news2024/9/25 17:18:34

嵌入一个SELECT的语句称为子查询语句。虽然内连接也可以代替子查询,但是内连接效率不高。而且我个人觉得子查询更好理解。


单值子查询

果子查询返回单值,则可以使用关系运算符,例如,等于(=)、不等于(<>)等,将其与主查询结合起来。下面通过例题举例说明。

 例 查询所有学生“心理学”的考试成绩,并以考试成绩降序进行排序。

分析:考试成绩在score表中,而该表中没有课名只有课号,所以首先必须从course表中查询“心理学”的课号,然后再从score表中根据查到的课号查询考试成绩。下面列出使用子查询完成查询任务的语句。

SELECT  s_id AS 学号, result1 AS 考试成绩 FROM    score
WHERE   c_id=(SELECT c_id  FROM course  WHERE course='心理学')
ORDER BY result1 DESC;

本例也可以使用内连接查询编写查询语句,具体语句如下所示。

SELECT  s_id AS 学号, result1 AS 考试成绩 FROM    score AS s,course AS c
WHERE   c.course='心理学'  AND s.c_id=c.ID
ORDER BY result1 DESC;
SELECT  s_id AS 学号, result1 AS 考试成绩
FROM    score AS s INNER JOIN course AS c ON s.c_id=c.ID
WHERE   c.course='心理学' 
ORDER BY result1 DESC;

 


子查询与聚合函数的配合使用

查询和聚合函数配合使用,其实是当前子查询的最大用途。因为,聚合函数通常都在SELECT子句字段列表处出现,而WHERE子句中又不能包含聚合函数,所以,通常是使用子查询获得聚合函数的返回值,然后将该返回值放到主查询中,最后再执行结合好后的查询语句。

例 查询出生日期最小(年龄最大)的学生的所有信息。

SELECT  * FROM   student
WHERE  birthday=(SELECT MIN(birthday) FROM student);

 

 

例 查询“心理学”考试成绩大于其考试成绩平均分的所有学生的学号、平时成绩和考试成绩。

SELECT s_id AS 学号, result2 AS 平时成绩, result1 AS 考试成绩 FROM   score
WHERE c_id=(SELECT ID FROM course WHERE course='心理学')
AND   result1>(SELECT AVG(result1) FROM  score WHERE c_id=(SELECT ID FROM course WHERE course='心理学'))
ORDER BY result1 DESC;

 将学生姓名也加上, 此时便需要将student表连接进来,

SELECT st.ID AS 学号, st.name AS 姓名,result2 AS 平时成绩, result1 AS 考试成绩
FROM  student AS st, score AS s, (SELECT ID FROM course  WHERE course='心理学') AS a
WHERE result1>(SELECT AVG(result1) FROM  score WHERE c_id=a.ID)
AND s.c_id=a.ID AND st.ID=s.s_id
ORDER BY result1 DESC;

 


列值子查询

查询所有课程类型为“必修”的学生的考试成绩,并按照课号进行升序排序。

如果使用子查询,本例的查询任务可以仅用一条语句完成,下面列出其具体语句。

SELECT  * FROM    score
WHERE  c_id IN (SELECT  ID FROM   course WHERE type='必修')
ORDER BY c_id, s_id;

 例 查询没有参加任何考试的学生的学号、姓名和所属院

SELECT  ID AS 学号, name AS 姓名, institute AS 所属院系 FROM    student
WHERE   ID NOT IN (SELECT DISTINCT s_id FROM     score)
ORDER BY ID;

 


相关子查询

相关子查询在子查询语句中调用了主查询用到的表字段。下面通过举例说明相关子查询的用法和其执行原理。

 例 从student表中,查询计科系所有学生的学号、姓名和考试总成绩,并按照考试总成绩降序排序。

SELECT ID AS 学号, name AS 姓名,(SELECT SUM(result1)FROM   score AS s WHERE s.s_id=st.ID) AS 考试总成绩
FROM   student AS st WHERE  institute='计算机学院'
ORDER BY 考试总成绩 DESC;

 如果使用表连接查询编写本例的查询语句,则其具体语句如下所示。

SELECT st.ID AS 学号,st.name AS 姓名,SUM(s.result1) AS 考试总成绩
FROM   student AS st,score AS s
WHERE  institute='计算机学院' AND    s.s_id=st.ID
GROUP BY st.ID, st.name
ORDER BY 考试总成绩 DESC;

运行结果同上。

若某个学生没有考试信息,那么就可能查不到。所以如果想查询所有计科系学生的考试信息,则应当使用左外连接,则其语句如下所示。

SELECT st.ID AS 学号,st.name AS 姓名,SUM(s.result1) AS 考试总成绩
FROM   student AS st LEFT JOIN score AS s ON s.s_id=st.ID
WHERE  institute='计算机学院'
GROUP BY st.ID, st.name
ORDER BY 考试总成绩 DESC;

运行结果同上。

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

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

相关文章

【C语言】“指针的运算”、“指针与数组”

文章目录一、指针运算1.指针 - 整数2.指针-指针3.指针关系运算二、指针与数组三、二级指针四、指针数组完结一、指针运算 指针可以进行整数&#xff0c;指针-指针&#xff0c;还有关系运算&#xff0c;其他的运算会被编译器阻止。 1.指针 - 整数 对指针进行的时候一定要注意不…

【SSM】篇一:初试Spring--Ioc与Bean

文章目录1、Spring2、SpringFramework系统架构3、Bean--Bean的配置Bean的实例化Bean的生命周期1、Spring Spring地址&#xff1a;https://spring.io Spring技术的优点&#xff1a; Spring家族&#xff08;Spring全家桶&#xff09;&#xff1a; 2、SpringFramework系统架构 S…

MySQL数据库10——多表连接查询

数据如果在多个表里面&#xff0c;需要进行连接查询。 一般在pandas里面merge合并会用到一个索引&#xff0c;按这个索引的规则进行合并叫做有规则的等值连接。若不按规则连接&#xff0c;遍历两两组合的所有可能性&#xff0c;叫做笛卡尔积。 笛卡尔积连接 通常人们都会设置…

R语言学习笔记

1.R语言介绍 2.R语言安装 官网&#xff1a;https://www.r-project.org/ CARN → 选择China中任意镜像站点 → Download R for Windows → base&#xff08;二进制版本R基础软件&#xff09;→ Download R-4.2.2 for Windows (76 megabytes, 64 bit) 3.Rstudio安装 https://po…

【Call for papers】SIGCOMM-2023(CCF-A/计算机网络/2023年2月15日截稿)

ACM SIGCOMM is the flagship annual conference of the ACM Special Interest Group on Data Communication (SIGCOMM). ACM SIGCOMM 2023, the 37th edition of the conference series, will be held in New York City, US, September 10 - 14, 2023. 文章目录1.会议信息2.时…

C语言(文件输入输出操作)

目录 一.文件 1.文件概念 2.文本模式和二进制模式 (1)模式结尾映射 (2)存储精度 3.I/O级别 一.文件 1.文件概念 文件:在磁盘或固态硬盘上一段已命名的存储区。对于C来说&#xff0c;文件就是一系列连续的字节&#xff0c;每个字节都能被单独读取&#xff08;在计算机当…

【C00033】基于Springboot的图书管理系统——有文档

基于Springboot的图书管理系统——有文档项目简介项目获取开发环境项目技术运行截图运行视频项目简介 基于springboot技术的图书管理系统主要是想研究一款高效且智能的图书管理系统&#xff0c;可以方便管理员以及借阅人员通过本系统更加快捷的完成图书借阅、查找等一系列操作…

ChatGPT不是聊天机器人,是任何人值得重视的竞争对手。

ChatGPT使用了一种聊天界面来和用户互动&#xff0c;用户的理解成本降低&#xff0c;通过输入文字&#xff0c;来得到各种反馈。有预见性的创造者们&#xff0c;已经挖掘ChatGPT所展示出来的各种能力应该如何更好地融入我们的日常生活中。比如&#xff0c;生成菜谱、音乐播放列…

1496奇怪的电梯(队列 广度优先搜索)

目录 题目描述 解题思路 代码部分 题目描述 大楼的每一层楼都可以停电梯&#xff0c;而且第i层楼&#xff08;1≤i≤N&#xff09;上有一个数字Ki(0≤Ki≤N&#xff09;。电梯只有四个按钮&#xff1a;开&#xff0c;关&#xff0c;上&#xff0c;下。上下的层数等于当前楼层…

套接字编程(四)TCP通信(万字详论)

TCP协议&#xff1a;面向连接的、可靠稳定的、基于字节流传输的通信协议 面向连接&#xff1a;通信之前首先要建立连接&#xff0c;确保双方具有收发数据的能力 可靠稳定的&#xff1a;通过大量的控制机制&#xff0c;保证数据能够安全有序且完整的到达对端 基于字节流&#xf…

【Vue3源码】第一章 effect和reactive

文章目录【Vue3源码】第一章 effect和reactive前言1、实现effect函数2、封装track函数&#xff08;依赖收集&#xff09;3、封装reactive函数4、封装trigger函数&#xff08;依赖触发&#xff09;5、单元测试【Vue3源码】第一章 effect和reactive 前言 今天就正式开始Vue3源码…

驱动 | Linux | NVMe 不完全总结

本文主要参考这里 1’ 2 的解析和 linux 源码 3。 此处推荐一个可以便捷查看 linux 源码的网站 bootlin 4。 更新&#xff1a;2022 / 02 / 11 驱动 | Linux | NVMe 不完全总结NVMe 的前世今生从系统角度看 NVMe 驱动NVMe CommandPCI 总线从架构角度看 NVMe 驱动NVMe 驱动的文件…

vue+nodejs考研资料分享系统vscode - Visual Studio Code

前端技术&#xff1a;nodejsvueelementui,视图层其实质就是vue页面&#xff0c;通过编写vue页面从而展示在浏览器中&#xff0c;编写完成的vue页面要能够和控制器类进行交互&#xff0c;从而使得用户在点击网页进行操作时能够正常。 Express 框架于Node运行环境的Web框架, 目 …

计算机网络5:数据在两台计算机之间是怎样传输的?

数据在两台计算机之间的传输总的来说包括了封装和解封两个过程 封装&#xff08;5层协议&#xff09; 以传送一张图片为例 **应用层&#xff1a;**将jpg格式的图片数据转化成计算机可以识别的0101的二进制的比特流 **传输层&#xff1a;**将应用层传输下来的数据进行分段&…

pandas数据分析35——多个数据框实现笛卡尔积

什么是笛卡尔积。就是遍历所有组合的可能性。 比如第一个盒子有[1,2,3]三个号码球&#xff0c;第二个盒子有[4,5]两个号码球。那么从每个盒子里面分别拿一个球共有3*2两种可能性&#xff0c;其集合就是{[1,4],[2,4],[3,4],[1,5],[2,5],[3,5]},这个就是笛卡尔积。 三个盒子也是…

GhostNet v2(NeurIPS 2022 Spotlight)原理与代码解析

paper&#xff1a;GhostNetV2: Enhance Cheap Operation with Long-Range Attentioncode&#xff1a;https://github.com/huawei-noah/Efficient-AI-Backbones/tree/master/ghostnetv2_pytorch背景在智能手机和可穿戴设备上部署神经网络时&#xff0c;不仅要考虑模型的性能&…

批量分析快递单号派件时效技巧

规定&#xff0c;如果出现派件延误商家没有及时处理&#xff0c;那么平台会对商家进行采取措施等等&#xff0c;同时商家每天都去跟踪自己发出单号物流状况&#xff0c;一个一个去查呢&#xff0c;不大可能&#xff0c;他们量是比较大&#xff0c;一个一个手动去官方查询工作量…

从元宇宙被认识的第一天开始,就注定了逃不脱区块链所经历的命运

从元宇宙被人们认识的第一天开始&#xff0c;它就注定了依然逃不脱它的先辈——区块链所经历的命运。如果对这样一种宿命进行一个总结的话&#xff0c;我更加愿意将其归结为以资本为主导的野蛮生长的发展模式。这种发展模式并不仅仅只是在区块链和元宇宙的身上出现&#xff0c;…

2016-ICLR-Order Matters- Sequence to sequence for sets

2016-ICLR-Order Matters- Sequence to sequence for sets Paper: [https://arxiv.org/pdf/1511.06391.pdf](https://arxiv.org/pdf/1511.06391.pdf) Code: 顺序重要性&#xff1a;集合的顺序到序列 摘要 许多需要从观察序列映射或映射到观察序列的复杂任务现在可以使用序列…

C++类基础(十一)

运算符重载&#xff08;二&#xff09; ● 对称运算符通常定义为非成员函数以支持首个操作数的类型转换 struct Str {int val 0;Str(int input): val(input){}auto operator(Str x){std::cout << "auto operator(Str x)\n";return Str(val x.val);} }; int …