sql中where和having的区别

拟墨画扇 提交于 2019-12-02 12:56:35

sql中where和having的区别

用的地方不一样

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

   having只能用于select语句中

执行的顺序不一样

   where的搜索条件是在执行语句进行分组之前应用

   having的搜索条件是在分组条件后执行的

   即如果where和having一起用时,where会先执行,having后执行

子句有区别

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

总结

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

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!