
代码如下: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) ;

代码如下: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字句就有结果了?