子查询是一个查询语句嵌套在另一个查询语句内部的查询,在SELECT子句中先计算子查询,其结果作为外层另一个查询的过滤条件。为了标记子查询与主查询之间的关系,通常将子查询写在小括号内。
查询可以基于一个表或多个表。
子查询可以添加到SELECT、UPDATE或者DELETE语句,进行多层嵌套。

带ANY、SOME关键字的子查询:ANY和SOME关键字是同义词,只要满足内层子查询中的任何一个比较条件,就返回一个结果作为外层查询的条件。

带ALL关键字的子查询:ALL关键字与ANY和SOME不同,使用ALL时需要同时满足所有内层查询的条件。

带IN关键字的子查询:内层查询语句仅仅返回一个数据列,这个数据列里的值将提供给外层查询语句进行比较操作。

带EXISTS关键字的子查询:EXISTS关键字后面的参数是一个任意的子查询,系统对子查询进行运算以判断它是否返回行,如果至少返回一行,那么EXISTS的结果为true,此时外层查询语句将进行查询;如果子查询没有返回任何行,那么EXISTS返回的结果是false,此时外层语句将不进行查询。

带比较运算符的子查询:在前面介绍的带ANY、ALL关键字的子查询时使用了>比较运算符,子查询时还可以使用其他的比较运算符,如<、<=、=、>=和!=等。

合并查询结果

利用UNION关键字,可以给出多条SELECT语句,并将它们的结果组合成单个结果集。合并时,两个表对应的列数和数据类型必须相同。各个SELECT语句之间使用UNION(执行的时候删除重复记录,所有返回的行是唯一的)或UNION ALL(不删除重复行也不对结果进行排序)关键字分隔。语法如下:

select 字段列表1  from  table1 
union [all]
select 字段列表2   from  table2...

说明:合并产生的新结果集的字段名与字段列表1中的字段名对应。