关于分组函数GROUPBY使⽤过程中count函数统计NULL值的问题
最近在⾃学MySQL,跟着视频练练⼿,遇到了⼀些⼩问题,先MARK下来,待以后继续慢慢思考
有两⾏表(其他⽤不上的字段先不考虑了):
员⼯表(包含员⼯ID、员⼯名、部门ID)
部门表(包含部门ID、部门名字)
现在要查询每个部门的员⼯⼈数,考虑⽤group by按部门进⾏分组查询,语法如下:
SELECT d.*,COUNT(*)⼈数
FROM departments d
LEFT JOIN employees e
ON e.department_id=d.department_id
GROUP BY d.department_id
⼜改成:
SELECT d.*,COUNT(d.department_id)⼈数
FROM departments d
LEFT JOIN employees e
ON e.department_id=d.department_id
GROUP BY d.department_id
最后结果都⼀样,有的部门没有员⼯,⼈数字段显⽰1,不符合实际。
然后思考了⼀下,视频弹幕说count员⼯字段(员⼯名或者员⼯ID),就可以显⽰0了,改了⼀下果然如此:
SELECT d.*,COUNT(employee_id)⼈数
FROM departments d
LEFT JOIN employees e
ON e.department_id=d.department_id
GROUP BY d.department_id
但是原因为啥啊!学渣表⽰百思不得其解啊,脑⼦糊了浆糊⼀般,所以去了解了group by和count字段关于Null值的描述:
*group by 将所有null值视为⼀项
count(字段/NULL) 不统计NULL值,count(null)=0
count(1)与count( * )得到的结果⼀致,包含null值
还有描述⽂档:
***COUNT returns the number of rows returned by the query. You can use it as an aggregate or analytic function.
If you specify DISTINCT, then you can specify only the query_partition_clause of the analytic_clause.
The order_by_clause and windowing_clause are not allowed.
If you specify expr, then COUNT returns the number of rows where expr is not null.
You can count either all rows, or only distinct values of expr.
If you specify the asterisk (), then this function returns all rows, including duplicates and nulls.
COUNT never returns null.**
所以,在⽤count(*)统计某些没有员⼯的部门的时候(此时表格已经左连,结果表上会显⽰每个部门下的所有员⼯,没有员⼯的部门会填充为null),所以这个时候会把没有员⼯的部门(员⼯被填充为NULL)算成1,包含了NULL值。所以不准确!应该直接统计关⼼的字段(⽐如员⼯姓名)
【总结】
⼀、注意语句的执⾏顺序(后续还要通过各种案例慢慢体会~)
from →join →on →where →group by→having→select→order by→limit
1、from⼦句百组装度来⾃不同数据源的数据;
2、where⼦句基于指定的条件对记录⾏进⾏筛问选;
3、group by⼦句将数据划分为多个分组答;
groupby分组4、使⽤聚集函数进⾏计算;
5、使⽤having⼦句筛选分组;
6、计算所有的表专达式(select);
7、使⽤order by对结果集进⾏排序。
8、分页显⽰
⼆、注意count的关于NULL值的计算
三、学渣⼩⽩继续要多做题,多分析。。。。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论