MySQL子查询的学习小结

发布时间:2019-12-11编辑:脚本学堂
本文介绍下,mysql子查询的一些知识,mysql学习笔记的一部分,用于掌握mysql中子查询的用法,有需要的朋友参考下。

mysql数据中的select语句支持子查询。
所谓子查询是将一个SELECT语句的查询结果作为中间结果,供另一个SELECT语句查询调用,子查询也叫做子选择或嵌套选择。

例如:
 

复制代码 代码示例:
SELECT studentNO
FROM (SELECT studentNO,sex
      FROM student
      WHERE age > 18) AS student18
WHERE sex='M'
 

以上sql语句中,从student表中查出年龄大于18的学号(studentNO)和性别(sex),作为中间结果集,并被命名为student18,然后从student18表中查出性别(sex)是男的('M')的学生的学号(studentNO)。
注,蓝色部分就是一个子查询。
 
一,子查询分类
子查询按返回结果集的不同分为4种:表子查询,行子查询,列子查询和标量子查询。
1)、表子查询:返回的结果集是一个表集合,N行N列(N>=1)。表子查询经常用于父查询的FROM子句中。
2)、行子查询:返回的结果集是一个表集合,一行N列(N>=1)。行子查询可以用于福查询的FROM子句和WHERE子句中。
3)、列子查询:返回的结果集是一个表集合,N行一列(N>=1)。
4)、标量子查询:返回的结果集是一个表集合,一行一列,也就是一个标量值。可以指定一个标量表达式的任何地方,都可以用一个标量子查询。
 
例如:行子查询
 

复制代码 代码示例:
SELECT studentNO
FROM student
WHERE (sex,age) = (SELECT sex,age
                   FROM student
                   WHERE studentNO = 15
                   )
 

查出学号(studentNO)是15的学生的性别和年龄(sex,age),是一个行表达式。
然后,查出性别和年龄与这个学生性别和年龄一样的学生的学号。
 
标量子查询,例如: 
 

复制代码 代码示例:
SELECT studentNO
FROM student
WHERE sex = (SELECT sex
             FROM student
             WHERE studentNO = 15
             )
 

查出学号(studentNO)是15的学生的性别sex,是一个标量表达式。
然后,查出性别与这个学生性别一样的学生的学号。