通过SQL case when语法实现统计SQL的纵表转横向

本文介绍如何使用SQL的CASE WHEN语句来实现从一张包含不同业绩类型的表中统计每位员工的新增、签约及跟进业绩,并计算总业绩的方法。

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

需求描述:

      有一张业绩统计表(t_user_performance),表结构如下:

人员ID
user_id
业绩类型
performance_type
业绩金额
performance_value
时间
create_date

      其中业绩类型是个枚举字段,有三种类型(新增、签约、跟进)。

      我需要统计买个人员每种业绩类型的总业绩,统计表格如下:

人员
新增业绩
签约业绩
跟进业绩
总业绩
小A
100
200
100
400
    上面表格是一个简单的纵表转横表的例子,我们可以通过case when的SQL语句直接实现上述功能:
   select user_id,
    count ( case performance_type when '新增' then '新增业绩' end )as 新增业绩 ,
    count ( case performance_type  when '签约' then '签约业绩' end )as 签约业绩 ,
    count ( case performance_type when '跟进' then '跟进业绩' end )as 跟进业绩,
    count (*) as 总业绩
   from t_user_performance  group by user_id

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值