也许有用的SQL:对单表数据进行count统计生成简单的交叉表

本文介绍了一种使用SQL查询来统计考勤记录的方法,通过case when语句汇总员工的考勤情况,包括上午早退、上午迟到、下午早退及下午迟到的次数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个表5个字段anghter代表是考勤信息,kaoqinid代表是考勤号,yeid区别上午早退与上午迟到,
下午早退与下午迟到,
0表示为上午早退,1表示为上午迟到,2表示为下午早退,3表示为下午早退
我想得到这样的查询效果
kaoqinid  上午早退  上午迟到   下午早退  下午早退


111111  8(次数)  21(次数)      11(次数)   12(次数)
222222  10(次数)  11(次数)     11(次数)   11(次数)
  
表中若干条记录数据如下:

angther    yeid       kaqinid
上午早退了    0            111111
下午迟到了    2            222222
下午迟到了    2            222222
下午迟到了    2             222222
上午迟到了   1           111111
上午早退了    0         111111
上午早退了   0        111111
下午迟到了   2          222222
下午早退了    3         222222
下午早退了    3           111111
下午迟到了    3          222222
下午早退了    3          222222
下午早退了    3          222222
下午迟到了    2          111111
下午早退了    3         111111
下午早退了    3         111111
下午迟到了    2        222222
下午早退了    3         222222
 

select kaqinid,
       sum(case when yeid='0' then 1 else 0 end),
       sum(case when yeid='1' then 1 else 0 end),
       sum(case when yeid='2' then 1 else 0 end),
       sum(case when yeid='3' then 1 else 0 end)
from t_anghter
group by 1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值