• 数据库-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

  • 相关阅读:
    Laravel5.0学习--03 Artisan命令
    yar框架使用笔记
    MySQL外键之级联
    笛卡尔积
    PHP钩子机制
    CentOS安装PHP7+Nginx+MySQL
    Linux压缩命令
    Git命令汇总
    使用List把一个长字符串分解成若干个短字符串
    Adb connection Error:远程主机强迫关闭了一个现有的连接
  • 原文地址:https://www.cnblogs.com/djhzzl/p/14317824.html
Copyright © 2020-2023  润新知