zoukankan      html  css  js  c++  java
  • Mysql 中 having 与 where 的区别

    我们在写sql语句的时候,经常会使用where语句,很少会用到having,其实在mysql中having子句也是设定条件的语句与where有相似之处但也有区别。having子句在查询过程中慢于聚合语句(sum,min,max,avg,count).而where子句在查询过程中则快于聚合语句(sum,min,max,avg,count)。 
    简单说来: 

    where子句: 
    select sum(num) as rmb from order where id>10 
    //只有先查询出id大于10的记录才能进行聚合语句 

    having子句: 
    select reportsto as manager, count(*) as reports from employees 
    group by reportsto having count(*) > 4 

    以test库为例.having条件表达示为聚合语句。肯定的说having子句查询过程慢于聚合语句。 
    再换句说话说把上面的having换成where则会出错。统计分组数据时用到聚合语句。 
    对分组数据再次判断时要用having。如果不用这些关系就不存在使用having。直接使用where就行了。 
    having就是来弥补where在分组数据判断时的不足。因为where要快于聚合语句。

  • 相关阅读:
    检测mysq组复制的脚本
    centos7安装NFS
    mysql组复制安装
    springboot+VUE(一)
    redis集群配置
    codevs 3139 栈练习3
    codevs 3138 栈练习2
    codevs 2622 数字序列
    codevs 1054 电梯
    codevs 1507 酒厂选址
  • 原文地址:https://www.cnblogs.com/caly/p/2340101.html
Copyright © 2011-2022 走看看