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

一个表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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值