SQL中where和having的区别详解

 更新时间:2021年02月08日 11:47:30   作者:秃头不用洗发水  
这篇文章主要给大家介绍了关于SQL中where和having区别的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

概念

where

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

聚合函数

对一组值执行计算,并返回单个值,也被称为组函数,经常与 SELECT 语句的 GROUP BY 子句的HAVING一同使用。例如

AVG 返回指定组中的平均值COUNT 返回指定组中项目的数量MAX 返回指定数据的最大值。MIN 返回指定数据的最小值。SUM 返回指定数据的和,只能用于数字列,空值被忽略。

having

having是一个过滤声明,是在查询数据库结果返回之后进行过滤,即在结果返回值后起作用,与聚合函数共同使用。

区别

使用group by进行过滤,则只能使用having。

执行顺序:where>聚合函数(sum,min,max,avg,count)>having,故where不使用聚合函数。

举个例子

职员表

 1、成绩大于8的有哪些?

使用where

 使用having

 报错,因为having是对已过滤后的结果,进行筛选,但是筛选出没有employee_score这个值,所以报错,如果加上则可以查出。

 

故where和having很多时候不能随意替代,主要是过滤对象不同。

2、每个部门年龄大于20的最高最低成绩?

 使用where也可以

 但是需要注意执行顺序

注意事项

在编写sql语句时,要注意where和group by的执行顺序,where应在前执行,group by 在后,否则会报错。

总结

到此这篇关于SQL中where和having的区别的文章就介绍到这了,更多相关SQL where和having区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 未在本地计算机上注册“Microsoft.Jet.OleDb.4.0”提供程序错误的解决方法

    未在本地计算机上注册“Microsoft.Jet.OleDb.4.0”提供程序错误的解决方法

    未在本地计算机上注册“Microsoft.Jet.OleDb.4.0”提供程序错误的解决方法,需要的朋友可以参考下。
    2011-08-08
  • 取随机记录的语句

    取随机记录的语句

    取随机记录的语句...
    2007-03-03
  • 大数据时代的数据库选择:SQL还是NoSQL?

    大数据时代的数据库选择:SQL还是NoSQL?

    执行大数据项目的企业面对的关键决策之一是使用哪个数据库,SQL还是NoSQL?SQL有着骄人的业绩,庞大的安装基础;而NoSQL正在获得可观的收益,且有很多支持者。我们来看看两位专家对这个问题的看法
    2014-03-03
  • 得物基于StarRocks的OLAP需求实践详解

    得物基于StarRocks的OLAP需求实践详解

    这篇文章主要为大家介绍了得物基于StarRocks的OLAP需求实践详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 用计算列实现移动加权平均算法

    用计算列实现移动加权平均算法

    昨天有人让我帮忙写个算移动加权平均的SQL语句,我想了半天终于写出来正确的了。现在发出来供大家参考、讨论。
    2009-09-09
  • 数据库分页查询语句数据库查询

    数据库分页查询语句数据库查询

    关于分页 SQL 的资料许多,有的使用存储过程,有的使用游标。本人不喜欢使用游标,我觉得它耗资、效率低;使用存储过程是个不错的选择,因为存储过程是颠末预编译的,执行效率高,也更灵活
    2014-08-08
  • [转载]让SQL运行得更快

    [转载]让SQL运行得更快

    笔者在工作实践中发现,不良的SQL往往来自于不恰当的索引设计、不充份的连接条件和不可优化的where子句。在对它们进行适当的优化后,其运行速度有了明显地提高!下面我将从这三个方面分别进行总结
    2007-02-02
  • Navicat数据库如何查找筛选某个值

    Navicat数据库如何查找筛选某个值

    这篇文章主要介绍了Navicat数据库如何查找筛选某个值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • 数据库中union 与union all 的区别

    数据库中union 与union all 的区别

    当我们要对两个或两个以上的表进行操作时。我们经常会用到union 与union all
    2009-11-11
  • 关于sql注入的简要演示(入坑抛砖)

    关于sql注入的简要演示(入坑抛砖)

    这篇文章主要介绍了关于sql注入的简要演示(入坑抛砖),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02

最新评论