代码如下:SELECT d.dname, ROUND(AVG(e.sal),2)
FROM emp e ,dept d
WHERE e.deptno=d.deptno
GROUP BY d.dname
HAVING AVG(sal)=(
SELECT MAX(AVG(sal))
FROM emp
GROUP BY deptno) ;
在第一次查询的时候,我忘记写WHERE字句,查询不出结果,但是WHERE字句不是为了消除笛卡儿积吗?为什么写上WHERE字句就有结果了?
没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。
多表查询必须指定关联查询条件的,你这里没有指定where关联条件的时候,直接使用笛卡尔积的话,可能就查都到结果了。