含义: 出现在其他语句中的select语句,成为子查询或内查询 外部的查询语句,成为主查询或外查询 分类: 按子查询出现的位置: select后面 仅仅支持标量子查询 from后面 支持表子查询 where或having后面 ★ 标量子查询(单行)✓ 列子查询(多行)✓ 行子查询 exists后面(相关子查询) 表子查询 按结果集的行列数不同: 标量子查询(结果集只有一行一列) 列子查询(结果集只有一列多行) 行子查询(结果集有一行多列) 表子查询(结果集一般为多行多列) #一、where或having后面 1、标量子查询(单行子查询) 2、列子查询(多行子查询) 3、行子查询(多列) 特点: ①子查询都会放在小括号内 ②子查询一般放在条件的右侧 ③标量子查询,一般搭配着单行操作符使用 > < >= <= = <> ④子查询的执行优先于主查询执行,主查询的条件用到了子查询的结果 列子查询:一般搭配着多行操作符使用 in 、 any/some 、 all #1、标量子查询 SELECT * FROM course; SELECT id FROM course WHERE credit = ( SELECT MIN(credit) FROM course ); #非法使用标量子查询 SELECT id FROM course WHERE credit = ( SELECT credit FROM course ); #2、列子查询(多行子查询) #3、行子查询(结果集一行多列或多行多列) #二、select后面 里面仅支持标量子查询 #三、from后面 将子查询结果充当一张表,且必须起别名 #四、exists后面(相关子查询) exists(完整的查询语句) 结果:1或0