WHERE和HAVING、ON有什么区别?

SQL 提供了多种对数据进行过滤的方式,包括 WHEREHAVING以及ON子句等。虽然它们都能够实现类似的功能,但是你知道它们之间的区别吗?

WHERE 和 HAVING、ON 有什么区别?

WHERE 与 HAVING

WHEREHAVING的根本区别在于:

  • WHERE子句在GROUP BY分组和聚合函数之前对数据行进行过滤;
  • HAVING子句对GROUP BY分组和聚合函数之后的数据行进行过滤。

因此,WHERE子句中不能使用聚合函数。

WHERE 与 ON

当查询涉及多个表的关联时,我们既可以使用WHERE子句也可以使用ON子句指定连接条件和过滤条件。这两者之间的主要区别在于:

  • 对于内连接(inner join)查询,WHEREON中的过滤条件等效;
  • 对于外连接(outer join)查询,ON中的过滤条件在连接操作之前执行,WHERE中的过滤条件(逻辑上)在连接操作之后执行。

对于内连接查询而言,以下三个语句的结果相同:

-- 语句 1
select d.dept_name, e.emp_name, e.sex, e.salary 
from employee e, department d
where e.dept_id = d.dept_id
and e.emp_id = 10;
dept_name|emp_name|sex|salary |
---------|--------|---|-------|
研发部   |廖化    ||6500.00|

-- 语句 2
select d.dept_name, e.emp_name, e.sex, e.salary 
from employee e
join department d on (e.dept_id = d.dept_id and e.emp_id = 10);
dept_name|emp_name|sex|salary |
---------|--------|---|-------|
研发部   |廖化    ||6500.00|

-- 语句 3
select d.dept_name, e.emp_name, e.sex, e.salary 
from employee e
join department d on (e.dept_id = d.dept_id)
where e.emp_id = 10;
dept_name|emp_name|sex|salary |
---------|--------|---|-------|
研发部   |廖化    ||6500.00|

语句 1 在WHERE中指定连接条件和过滤条件;语句 2 在ON中指定连接条件和过滤条件;语句 3 在ON中指定连接条件,在WHERE中指定其他过滤条件。

尽管如此,仍然建议将两个表的连接条件放在ON子句中,将其他过滤条件放在WHERE子句中;这样语义更加明确,更容易阅读和理解。对于上面的示例而言,推荐使用语句 3 的写法。

对于外连接而言,连接条件只能用ON子句表示,因为WHERE子句无法表示外连接的语义。


Update time: 2020-08-18

results matching ""

    No results matching ""