目录
子查询的概念子查询的分类按照子查询出现的位置分类:where或having后面1、标量子查询2、列子查询3、行子查询
select后面from后面exists后面
子查询的概念
子查询
(也称内查询
)含义
: 出现在其他语句中的select语句,称为子查询或内查询。
外部的查询语句,称为主查询或外查询。
子查询的分类
按照子查询出现的位置分类:
select后面: 仅仅支持标量子查询from后面: 支持表子查询where或having后面: 标量子查询(用的多) 列子查询(用的多) 行子查询(用的少)exists后面(相关子查询): 表子查询
按结果集的行列数不同分类:
标量子查询(结果集只有一行一列)列子查询(结果集只有一列多行)行子查询(结果集有一行多列)表子查询(结果集一般为多行多列)
按照子查询出现的位置分类:
where或having后面
1.标量子查询(单行子查询)2.列子查询(多行子查询)3.行子查询(多列多行)
特点:
1.子查询放在小括号内2.子查询一般放在条件的右侧3.标量子查询,一般搭配着单行操作符 (> < >= <= = <>)使用 列子查询一般搭配着多行操作符使用 in 、 any/some 、 all 。4.子查询的执行优先于主查询执行,主查询的条件用到了子查询的结果。
1、标量子查询
非法使用标量子查询 子查询不是一行一列
2、列子查询
列子查询
(多行子查询
): 返回多行,使用多行比较操作符。
操作符含义
IN / NOT IN等于列表中的任意一个ANY / some和子查询返回的某一个值比较ALL和子查询返回的所有值比较
3、行子查询
select后面
select后面的子查询 仅仅支持标量子查询
from后面
将子查询充当一张表,要求必须起别名。
exists后面