简单的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会给我们处理好】

 

 

 

转载于:https://www.cnblogs.com/libin6505/p/10499604.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值