简单的sql分组统计

Posted 戈博小刀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了简单的sql分组统计相关的知识,希望对你有一定的参考价值。

一个记录员工打卡时间的表,只有两个有效字段 员工名称,打卡时间,现在要统计某一天中,每个员工的打卡次数、最早打卡时间、最晚打卡时间,问sql怎么写?

其实这个sql很简单,

 

1、首先要明确既然是按每个员工统计每个员工的打卡时间,那么一定是按照员工名称分组,所以   可以得到

sql 片段1: group by name

 

2、要明确,我们需要的所有字段都应该出现在最外层的select 后面,不管是否分组

 那么我们可以写出

sql片段2: select name,count(*),min(tdate),max(tdate)

 

3、把 片段2和片段1组合就得到最终结果了。

 

【其实我们统计结果中一定是每个员工一条记录,也就是说每条记录中的字段都是从当前员工所有打卡记录里面生成的,也就是说我们的查询条件字段实际上都是针对每个员工组里面的统计的,

只是我们把它们写在 最外层的 select 后面,我们写的时候不用考虑数据是怎么生成的,我们只要知道,我们需要哪些字段,就写在 select后面,按照什么分组就写在 group by 后面,其他的事不用我们管,mysql会给我们处理好】

 

 

 

以上是关于简单的sql分组统计的主要内容,如果未能解决你的问题,请参考以下文章

SQL 分组统计,再合并组

SQL按月统计,按日分组

SQL 分组统计并排序

sql中根据表中一个字段分组分别统计每个分组的记录数

sql 数据分组统计与合计

COUNT分组条件去重的sql统计语句示例(mysql)