• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • sql语句中where和having的区别
    • SQL 中having 和where的区别分析
    • sql中的 where 、group by 和 having 用法解析
    • SQL中where子句与having子句的区别小结
    • 数据库SQL中having和where的用法区别
    • SQL中Having与Where的区别
    • SQL中Having与Where的区别及注意
    上一篇:JetBrains出品一款好用到爆的DataGrip数据库工具使用入门
    下一篇:关于Navicat连接MySql数据库慢的问题
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQL中where和having的区别详解 SQL,中,where,和,having,的,区别,