分享

(MySQL笔记)MySQL子查询

 CevenCheng 2011-09-04
    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,是一个标量表达式。然后查出性别与这个学生性别一样的学生的学号。
 
 

 TAG MySQL SELECT 子查询

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多