数据库中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的具体用法,明白了吗?

原文地址:https://www.cnblogs.com/muhy/p/10571583.html