MySQL子查询怎么操作
一. 子查询
什么是子查询呢?健哥来为各位小伙伴细细道来。所谓子查询就是将一个查询结果作为判断条件或者作为一张虚拟表在这个结果的基础上进行另一个查询。
1.子查询(作为条件判断)
下面就是将查询结果作为另一个查询的判断条件。
语法 : SELECT 列名 FROM 表名 Where 条件 (子查询结果)
举个例子:查询和健哥同岁的其他同学。


注意 : 将子查询 ”一行一列“的结果作为外部查询的条件,做第二次查询子查询得到一行一列的结果才能作为外部查询的等值判断条件或不等值条件判断。
2.子查询(作为枚举查询条件)
子查询作为枚举查询条件使用是将一个查询结果(单列多行)的结果集作为枚举查询条件进行二次查询。
语法 :SELECT 列名 FROM 表名 Where 列名 in(子查询结果);
举个栗子:查询和健哥,旭哥同龄的学生信息。


将子查询 ”多行一列“的结果作为外部查询的枚举查询条件,做第二次查询。
3.子查询(作为一张表)
此处健哥敲黑板啦!非常重要,使用频率很高!
下面的子查询是将一个查询的结果当做一张虚拟表,然后在这个表的结果基础上再进行查询。
语法 :SELECT 列名 FROM (子查询的结果集) WHERE 条件;
举个栗子:查询最老的5名学生信息。


将子查询 ”多行多列“的结果作为外部查询的一张表,做第二次查询。
注意: 子查询作为临时表,为其赋予一个临时表名。

浙公网安备 33010602011771号