码迷,mamicode.com
首页 > 其他好文 > 详细

HAVING和WHERE的区别

时间:2018-12-18 13:59:05      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:执行   from   的区别   作用   where   student   执行顺序   区别   sele   

1.类型:

“Where”是一个约束声明,在查询数据库的结果返回之前对数据库中的查询条件进行约束,即在结果返回之前起作用,且where后面不能使用“聚合函数”;

“Having”是一个过滤声明,所谓过滤是在查询数据库的结果返回之后进行过滤,即在结果返回之后起作用,并且having后面可以使用“聚合函数”。

2.使用的角度:

where后面之所以不能使用聚合函数是因为where的执行顺序在聚合函数之前,

如下面这个sql语句:select  sum(score) from student  group by student.sex where sum(student.age)>100;

having既然是对查出来的结果进行过滤,那么就不能对没有查出来的值使用having,

如下面这个sql语句:  select  student.id,student.name from student having student.score >90;

HAVING和WHERE的区别

标签:执行   from   的区别   作用   where   student   执行顺序   区别   sele   

原文地址:https://www.cnblogs.com/konglxblog/p/10136505.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!