当我们创建出很多分组的时候,有时候就需要对分组进行过滤。你可能首先会想到WHERE子句,实际上过滤分组我们使用的是HAVING。HAVING的作用和WHERE一样,都是起到过滤的作用,只不过WHERE是用于数据行,而HAVING则作用于分组。
比如我们想要按照英雄的主要定位、次要定位进行分组,并且筛选分组中英雄数量大于5的组,最后按照分组中的英雄数量从高到低进行排序。
首先我们需要获取的是英雄的数量、主要定位和次要定位,即SELECT COUNT(*) as num, role_main, role_assist
。然后按照英雄的主要定位和次要定位进行分组,即GROUP BY role_main, role_assist
,同时我们要对分组中的英雄数量进行筛选,选择大于5的分组,即HAVING num > 5
,然后按照英雄数量从高到低进行排序,即ORDER BY num DESC
。
SELECT COUNT(*) as num, role_main, role_assist FROM heros GROUP BY role_main, role_assist HAVING num > 5 ORDER BY num DESC
运行结果:(4条记录)
你能看到还是上面这个分组,只不过我们按照数量进行了过滤,筛选了数量大于5的分组进行输出。如果把HAVING替换成了WHERE,SQL则会报错。对于分组的筛选,我们一定要用HAVING,而不是WHERE。另外你需要知道的是,HAVING支持所有WHERE的操作,因此所有需要WHERE子句实现的功能,你都可以使用HAVING对分组进行筛选。
我们再来看个例子,通过这个例子查看一下WHERE和HAVING进行条件过滤的区别。筛选最大生命值大于6000的英雄,按照主要定位、次要定位进行分组,并且显示分组中英雄数量大于5的分组,按照数量从高到低进行排序。
SELECT COUNT(*) as num, role_main, role_assist FROM heros WHERE hp_max > 6000 GROUP BY role_main, role_assist HAVING num > 5 ORDER BY num DESC
运行结果:(2条记录)
你能看到,还是针对上一个例子的查询,只是我们先增加了一个过滤条件,即筛选最大生命值大于6000的英雄。这里我们就需要先使用WHERE子句对最大生命值大于6000的英雄进行条件过滤,然后再使用GROUP BY进行分组,使用HAVING进行分组的条件判断,然后使用ORDER BY进行排序。