一个记录员工打卡时间的表,只有两个有效字段 员工名称,打卡时间,现在要统计某一天中,每个员工的打卡次数、最早打卡时间、最晚打卡时间,问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会给我们处理好】