gpt4 book ai didi

sql - 使用 PostgreSQL 计算和添加在特定日期出现的不同值

转载 作者:行者123 更新时间:2023-11-29 14:13:49 25 4
gpt4 key购买 nike

在一些数据库的表中使用一些 SQL,我得到这样的结果:

id  name    date            status
1 John 2018-05-03 PRESENT
2 Mary 2018-05-03 NOT PRESENT
3 Jane 2018-05-03 NOT PRESENT
2 Mary 2018-05-04 PRESENT
1 John 2018-05-04 PRESENT
1 John 2018-05-05 PRESENT
2 Mary 2018-05-05 NOT PRESENT
3 Jane 2018-05-04 PRESENT
3 Jane 2018-05-05 NOT PRESENT
1 John 2018-05-06 PRESENT

我想使用更多的 SQL 来获得这样的结果:

id  name    date      present   not present
1 John 2018-05 4 0
2 Mary 2018-05 1 2
3 Jane 2018-05 2 1

换句话说,我想根据他/她每天收到的状态提取学生在给定月份参加了多少节课。我怎样才能做到这一点?

最佳答案

使用条件聚合:

select id, name, to_char(date,'YYYY-MM') as "Date", 
sum(case when status = 'PRESENT' then 1 else 0 end ) as present,
sum(case when status = 'NOT PRESENT' then 1 else 0 end ) as not_present
from tab
group by id, name, "Date"
order by id

Demo

  • 保持 else 为 0 对于 null 返回案例获取 0 很重要
  • 选择列表中的列别名可能会在group by 列表中使用对于 Postgres

  • 由于所需的输出,将日期值截断为月份需要 to_char(date,'YYYY-MM')

关于sql - 使用 PostgreSQL 计算和添加在特定日期出现的不同值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56401997/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com