SQL子查询、相关子查询

版权声明:最终解释权归属Hern所有,恒! https://blog.csdn.net/qq_36761831/article/details/83243199

子查询

子查询是嵌套在其他查询中的查询。子查询总是从内向外处理。

注意:

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.类编号
  )

猜你喜欢

转载自blog.csdn.net/qq_36761831/article/details/83243199