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

mysql having和where的区别 数据库里where和having的区别_数据

 

工具/原料

 

  • 数据库

方法/步骤

 

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

    mysql having和where的区别 数据库里where和having的区别_数据库_02

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

    mysql having和where的区别 数据库里where和having的区别_数据_03

  3.  
    而having是要配合group by 使用,在分组之后过滤数据。所以总结一句话,
    where在group by之前执行,having 在group by 之后执行。where和having 可以同时存在一个SQL语句中。

    mysql having和where的区别 数据库里where和having的区别_数据_04

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

    mysql having和where的区别 数据库里where和having的区别_数据库_05

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

    mysql having和where的区别 数据库里where和having的区别_sql_06

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

    mysql having和where的区别 数据库里where和having的区别_数据_07

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