Java教程

面试常见SQL中where和having的区别你确定你知道吗!

本文主要是介绍面试常见SQL中where和having的区别你确定你知道吗!,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

“Where” 是一个约束声明,使用Where来约束来之数据库的数据,Where是在结果返回之前起作用的,且Where中不能使用聚合函数。

“Having” 是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作,在Having中可以使用聚合函数。

本质的区别就是where筛选的是数据库表里面本来就有的字段,而having筛选的字段是从前筛选的字段筛选的。

where和having都可以使用的场景:

SELECT的语法顺序就是起执行顺序

FROM
WHERE (先过滤单表/视图/结果集,再JOIN)
GROUP BY
HAVING (WHERE过滤的是行,HAVING过滤的是组,所以在GROUP之后)
ORDER BY

1、可用于的语句不用

where可以用于select、update、delete和insert into values(select * from table where ..)语句中。
having只能用于select语句中
‘’

2、执行的顺序不一样

where的搜索条件是在执行语句进行分组之前应用
having的搜索条件是在分组条件后执行的
即如果where和having一起用时,where会先执行,having后执行

3、子句有区别

where子句中的条件表达式having都可以跟,而having子句中的有些表达式where不可以跟;having子句可以用集合函数(sum、count、avg、max和min),而where子句不可以。

4、总结

1.WHERE 子句用来筛选 FROM 子句中指定的操作所产生的行。
2.GROUP BY 子句用来分组 WHERE 子句的输出。
3.HAVING 子句用来从分组的结果中筛选行

这篇关于面试常见SQL中where和having的区别你确定你知道吗!的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!