史上最简单的 MySQL 教程(三十一)「子查询(上)」

子查询

子查询sub query,查询是在某个查询结果之上进行的,一条select语句内部包含了另外一条select语句。

分类

子查询有两种分类方式,分别为:按按结果分类和位置分类。

按结果分类,即根据子查询得到的数据进行分类(理论上,任何一个查询结果都可以理解为一个二维表),分别为:

  • 标量子查询:子查询得到的结果是一行一列,出现的位置在where之后;
  • 列子查询:子查询得到的结果是一列多行,出现的位置在where之后;
  • 行子查询:子查询得到的结果是多行一列(多行多列),出现的位置在where之后;
  • 表子查询:子查询得到的结果是多行多列,出现的位置在from之后。

按位置分类,即根据子查询(select语句)在外部查询(select语句)中出现的位置进行分类,分别为:

  • from子查询:子查询出现在from之后;
  • where子查询:子查询出现在where条件之中;
  • exists子查询:子查询出现在exists里面。

标量子查询

需求:现知道班级名称为PM3.1,想要获取该班的全部学生。

思路

  • 先确定数据源,学生表。
  • select * from st

你可能感兴趣的:(数据库,史上最简单的,MySQL,教程)