(MySQL笔记)MySQL子查询
MySQL的SELECT语句中支持子查询。子查询是将一个SELECT语句的查询结果作为中间结果,供另一个SELECT语句查询调用,子查询也叫做子选择或者嵌套选择。如:
SELECT studentNO FROM (SELECT studentNO,sex FROM student WHERE age > 18) AS student18 WHERE sex='M'
|
从student表中查出年龄大于18的学号(studentNO)和性别(sex),作为中间结果集,并被命名为student18,然后从student18表中查出性别(sex)是男的('M')的学生的学号(studentNO)。
蓝色部分就是一个子查询。
子查询分类
子查询按返回结果集的不同分为4种:表子查询,行子查询,列子查询和标量子查询。
表子查询:返回的结果集是一个表集合,N行N列(N>=1)。表子查询经常用于父查询的FROM子句中。
行子查询:返回的结果集是一个表集合,一行N列(N>=1)。行子查询可以用于福查询的FROM子句和WHERE子句中。
列子查询:返回的结果集是一个表集合,N行一列(N>=1)。
标量子查询:返回的结果集是一个表集合,一行一列,也就是一个标量值。可以指定一个标量表达式的任何地方,都可以用一个标量子查询。
如:行子查询
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,是一个标量表达式。然后查出性别与这个学生性别一样的学生的学号。
阅读(3071) | 评论(0) | 转发(0) |