首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

你了解sql查询吗?你知道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 ...);

二、查询实例

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

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

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

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

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20191013A03RNJ00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券