方法/步骤
-
当然,在数据库中,如何正确的使用where与having,首先,要弄清楚这两个名词在数据库中的定位。where在sql中是一个约束声明,使用where来约束数据库的数据。
-
having是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作。此外,区别两个名词的还有一个分组,就是group by,where条件是不需要分组的,在分组之前过滤数据,所以where字句中不包含聚组函数。
-
而having是要配合group by 使用,在分组之后过滤数据。所以总结一句话,
where在group by之前执行,having 在group by 之后执行。where和having 可以同时存在一个SQL语句中。
-
在这里做一个简单的例子,这边有一张sales表格,里面有name,sex,salary,dept四个字段,通过select × from sales可以查询到表中所有的内容。
-
然后接下来使用where查询性别为男性的所有数据,具体的语句为:select * from sales where sex='男'。这里面就是使用where来进行筛选,不需要进行组合语句。
-
然后使用having,这里面的having是一定要配合group by 一起使用的,而where可有可无,然后having是基于对表进行分组之后,然后再进行筛选。
-
以上就是where 与having的具体用法,明白了吗?