子查询
子查询是嵌套在其他查询中的查询。子查询总是从内向外处理。
注意:
1、在使用子查询时尽量把子查询分解为多行并且适当进行缩进,能极大的简化子查询的使用。
2、不能嵌套太多的子查询,这样会降低性能。
3、在WHERE子句中使用子查询,应该保证SELECT语句具有与WHERE子句中相同数目的列。
4、通常子查询将返回单个列并且与单个列进行匹配,但如果需要也可以使用多个列。
语法举例:
city表中 CountryCode 列中开头包含 A 或 B 的 序号,并将符合要求的信息全部输出
SELECT *
FROM city
WHERE ID IN(
SELECT ID
FROM city
WHERE CountryCode REGEXP '[A|B]'
ORDER BY ID
);
相关子查询
相关子查询是涉及外部查询的子查询。
执行过程:
(1)从外层查询中取出一个元组,将元组相关列的值传给内层查询。
(2)执行内层查询,得到子查询操作的值。
(3)外查询根据子查询返回的结果或结果集得到满足条件的行。
(4)然后外层查询取出下一个元组重复做步骤1-3,直到外层的元组全部处理完毕。
语法举例
查询Booka表中大于该类图书价格平均值的图书信息SElECT 图书名,出版社,类编号,价格
SELECT FROM Books As a
WHERE 价格 >
(
SELECT AVG(价格)
FROM Books AS b
WHERE a.类编号=b.类编号
)