mysql的where子查询_mysql子查询

原标题:mysql子查询

一、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 ...);

二、查询实例

下图为成绩表和班级表数据。

a6337d253f98eea8ab01cfbfeffd80b8.png

1.查询成绩表中数学成绩最高的学生信息;

e7107e7abda485e2da4becc61f997435.png

2.查询成绩表中各个班级的最高总成绩;

115e2ac3297ea56195e0bcfab70dbaea.png

3.根据成绩表和班级表,找出成绩表中缺失成绩的班级;

责任编辑:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值