子查询(内查询)

子查询的概念

子查询(也称内查询)含义: 出现在其他语句中的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后面

在这里插入图片描述
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_46527915/article/details/109226992