• 数据库中where与having区别


    在初学数据库的时候,会经常用到一些数据库语句去查询数据库中的表,不管是oracle、mysql、db2、还是sqlserver,数据库的语法都大同小异。而在使用sql语句的过程中,会经常遇到一些问题,诸如数据库中where与having区别?

    数据库中where与having区别
     

    工具/原料

     
    • 数据库

    方法/步骤

     
    1.  

      当然,在数据库中,如何正确的使用where与having,首先,要弄清楚这两个名词在数据库中的定位。where在sql中是一个约束声明,使用where来约束数据库的数据。

      数据库中where与having区别
    2.  

      having是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作。此外,区别两个名词的还有一个分组,就是group by,where条件是不需要分组的,在分组之前过滤数据,所以where字句中不包含聚组函数。

      数据库中where与having区别
    3.  

      而having是要配合group by 使用,在分组之后过滤数据。所以总结一句话,

      where在group by之前执行,having 在group by 之后执行。where和having 可以同时存在一个SQL语句中。

      数据库中where与having区别
    4.  

      在这里做一个简单的例子,这边有一张sales表格,里面有name,sex,salary,dept四个字段,通过select × from sales可以查询到表中所有的内容。

      数据库中where与having区别
    5.  

      然后接下来使用where查询性别为男性的所有数据,具体的语句为:select * from sales where sex='男'。这里面就是使用where来进行筛选,不需要进行组合语句。

      数据库中where与having区别
    6.  

      然后使用having,这里面的having是一定要配合group by 一起使用的,而where可有可无,然后having是基于对表进行分组之后,然后再进行筛选。

      数据库中where与having区别
    7. 7

      以上就是where 与having的具体用法,明白了吗?

  • 相关阅读:
    python3-while与if
    python3-while与continue
    python3-password在输入密码时隐藏密码
    input与字符串格式化
    for与break的用法
    bochs 2.6.8 常用命令集合
    关于8086中的jmp near ptr原理
    如何学习Python课程
    微信公众号去除密码安全提示
    模块的使用
  • 原文地址:https://www.cnblogs.com/muhy/p/10571583.html
Copyright © 2020-2023  润新知