Chinaunix首页 | 论坛 | 博客
  • 博客访问: 276024
  • 博文数量: 30
  • 博客积分: 1425
  • 博客等级: 上尉
  • 技术积分: 340
  • 用 户 组: 普通用户
  • 注册时间: 2007-03-03 12:59
文章分类

全部博文(30)

文章存档

2010年(14)

2009年(8)

2008年(8)

我的朋友

分类: Mysql/postgreSQL

2010-06-12 12:02:56

(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,是一个标量表达式。然后查出性别与这个学生性别一样的学生的学号。
 
 
阅读(3034) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~