zoukankan      html  css  js  c++  java
  • Where和having都是条件筛选关键字,它们有什么分别?

    WHERE是在数据分组前进行条件过滤, HAVING子句是在数据分组后进行条件过滤,WHERE子句中不能使用聚合函数,HAVING子句可以使用聚合函数

     

    需要注意说明当同时含有where子句、group by 子句 、having子句及聚集函数时执行顺序如下

    A、执行where子句查找符合条件的数据

    B、函数计算每一组的值最后用having 子句去掉不符合条件的组

    C、having 子句中的每一个元素也必须出现在select列表中有些数据库例外oracle.

    D、having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制

    E、having子句限制的是组而不是行。where子句中不能使用聚集函数having子句中可以

    1求平均工资大于2000的部门 
      select dept_id,avg(salary) from s_emp group by dept_id having avg(salary)>2000;

     

    例子2:查询求各个部门的最小最高工资之和部门名称 
    select e.dept_id,d.name,min(salary),max(salary),sum(salary) from s_emp e ,s_dept d where e.dept_id=d.id group by e.dept_id,d.name;

     

    使用group by 常见的错误
    如果在select语句中没有出现group by子句那么不能在select子句中同时出现单个列名和组函数的混合现象

    如果希望限制分组中的数据那么可以使用having子句而不能使用where子句having中可以出现组函数而where不能出现组函数

  • 相关阅读:
    将戴尔台式机的系统刷成Linux Centos7
    如何在Maven构建的Java项目中使用log4j
    mybatis-generator逆向工程自动生成mapper
    Win10改变系统主题颜色,降低对眼睛的刺激
    09、SpringBoot 整合 jdbcTemplate、Mybatis
    08、SpringBoot配置拦截器
    navicat快捷键
    DevOps:从理念到实施
    活到老学到老啊技术人
    Linux上安装java+tomcat+mysql运行环境
  • 原文地址:https://www.cnblogs.com/programb/p/12845119.html
Copyright © 2011-2022 走看看