一、mysql子查询基本知识
子查询就是在原有的查询语句中,嵌入新的查询,来得到我们想要的结果集。
子查询一般分为:where型子查询、from型子查询和exists型子查询。
1.where型子查询:将内层查询结果当做外层查询的比较条件。
select 列1,列2,...,列n from 表名 where 列i =/in (select 列1,列2,...,列n from 表名 where ...);
2.from型子查询:把内层的查询结果当成临时表,供外层sql再次查询。查询结果集可以当成表看待。临时表要使用一个别名。
select 列1,列2,...,列n from (select 列1,列2,...,列n from 表名 where ...) as 表别名 where ....;
3.exists型子查询:把外层sql的结果,拿到内层sql去测试,如果内层的sql成立,则该行取出。内层查询是exists后的查询。
select 列1,列2,...,列n from 表名 where exists (select 列1,列2,...,列n from 表名 where ...);
二、查询实例
下图为成绩表和班级表数据。
1.查询成绩表中数学成绩最高的学生信息;
2.查询成绩表中各个班级的最高总成绩;
3.根据成绩表和班级表,找出成绩表中缺失成绩的班级;
继续阅读与本文标签相同的文章
下一篇 :
Python3 time.gmtime()方法
-
大反转!谷歌态度开始“服软”,华为即将获得GMS许可
2026-05-14栏目: 教程
-
Python 超简单实现9种图像风格迁移
2026-05-14栏目: 教程
-
华为打回欧洲市场!HMS取得重大成功,大量APP接入!谷歌慌不慌?
2026-05-14栏目: 教程
-
PS保存图片提示“无法完成请求”,这里有4种解决方法!
2026-05-14栏目: 教程
-
想买1000元左右的5G手机?我们需要等多久?
2026-05-14栏目: 教程
