zoukankan      html  css  js  c++  java
  • 数据库-where和having的区别

    数据库-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 在后,否则会报错。

    参考资料

    https://blog.csdn.net/qq_41587243/article/details/83022883?utm_medium=distribute.pc_relevant_t0.none-task-blog-searchFromBaidu-1.control&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-searchFromBaidu-1.control

  • 相关阅读:
    I/O多路复用
    Django重点之url别名
    10 个常用的 Linux 命令?
    软连接和硬链接的区别?
    Linux 重定向命令有哪些?有什么区别?
    在 linux 中 find 和 grep 的区别??
    Django中用 form 实现登录注册
    你所遵循的PEP8代码规范是什么?请举例说明其要求?
    什么是 Python 的命名空间?
    ELK+Kafka日志收集环境搭建
  • 原文地址:https://www.cnblogs.com/djhzzl/p/14317824.html
Copyright © 2011-2022 走看看