Mysql 按照记录的日期分组,并将结果按照某字段分组聚合

遇到一个需求是将表内的数据按日期分组聚合,不过其中有个类型字段,需要同时将类型的值也做个分组聚合。请问应该如何写sql最优:

数据表结构

create table record
(
    id int unsigned auto_increment
        primary key,
    amount int(10) default 0 not null comment '记录金额',
    type tinyint(1) not null comment '记录类型 1 支出 2收入 3其他',
    create_time datetime null
)

通过sql可以达到按天的分组,但是如何将type也按照每天分组做个统计

select DATE_FORMAT(create_time,'%Y-%m-%d') as day,sum(amount) amount,type from record group by DATE_FORMAT(create_time,'%Y-%m-%d')

期望查询出来的每行结果为如下字段:
day amount type_1_amount type_2_amount type_3_amount
请问这样效果应该如何实现?

阅读 4.4k
1 个回答

我猜你type_1_amounttype_2_amount分别表示的是每日支出和收入总额,那SQL就这样:

select DATE_FORMAT(create_time,'%Y-%m-%d') as day,
  sum(amount) amount,
  sum(if(type=1,amount,0)) type_1_amount,
  sum(if(type=2,amount,0)) type_2_amount,
  sum(if(type=3,amount,0)) type_3_amount
from record 
group by DATE_FORMAT(create_time,'%Y-%m-%d')
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题