嵌套查询简单来说就是有子查询的SQL语句,子查询可以出现在SLECT, FROM或者WHERE 子句中,也可以单独用WITH子句来定义一个子查询。使用时子查询可以将一个复杂的查询拆分成一个个独立的部分,逻辑上更易于理解以及代码的维护和重复使用。有利于程序查询缓存,减少锁的竞争,减少查询冗余,应用层面相当于实现哈希关联。更容易对数据库进行拆分,做到高可用,易拓展,解耦。但是子查询另一个很明显的问题就是效率比较低,比如创建临时表和查询时重复扫表。所以我们可以根据不同的嵌套查询类型进行查询优化。
嵌套查询的几种主要类型
1.类型A:子查询返回的值是一个聚集函数的结果,并且与外查询独立,即子查询不使用外查询表中的字段。例如:
SELECT *
FROM exam e
WHERE e.grade = (SELECT max(grade) FROM exams)
这里查询执行时先遍历exam表,过程中exam表的每个元组都要再遍历得出最高的分数,即重复遍历表和计算。
由于子查询没有用到外查询的表exam, 所以可以单独估算子查询的开销,即看作一个常数。
所以可以直接定义该子查询为一个常量,如下:
DEFINE m = (SELECT max(grade) FROM exams)
SELECT *
FROM exam e
WHERE e.grade = m
2.类型N:子查询不包含与外查询的任何连接操作,并且没有聚集函数。例如:
SELECT *
FROM exam e
WHERE e.department IN (SELECT f.id
FROM