问题描述
我尝试根据我的表格数据计算平均持续时间(天)。在这个表中,我有三列:
- audit_process_completed(这是结束日期/格式:YYYY-MM-DD)
- audit_decision_date(这是开始日期/格式:YYYY-MM-DD)
- audit_created(如果 'audit_decision_date' (2.) = '0000-00-00',则这是替代开始日期
我现在想计算 1 到 2(如果不是 '0000-00-00')或 3(如果 2. 是 '0000-00-00')之间的天时差。在开始 CASE
之前,我尝试使用 sql AVG(DATEDIFF)
定义正确的开始日期。请检查尝试。我无法为此找到正确的解决方案。
SELECT audit_created,audit_decision_date,audit_process_completed
CASE audit_decision_date WHEN '0000-00-00' THEN audit_created ELSE audit_decision_date END AS start_date
(SELECT AVG(DATEDIFF (audit_process_completed,start_date)) AS duration
FROM audit WHERE general_audit_status = 'Abgeschlossen' AND assigned_auditor = 2
样本数据:
id | audit_process_completed | audit_decision_date | audit_created |
---|---|---|---|
1 | 2021-01-22 | 2021-01-17 | 2021-01-17 |
2 | 2021-01-27 | 0000-00-00 | 2021-01-20 |
3 | 2021-01-28 | 0000-00-00 | 2021-01-22 |
4 | 2021-02-01 | 2021-01-30 | 2021-01-24 |
期望的输出: 整个表格的平均持续时间(以天为单位)。
解决方法
假设您使用的是 MySQL,您似乎需要 case
的 avg()
逻辑:
select avg(datediff( audit_process_completed,(case when audit_decision_date <> '0000-00-00' then audit_decision_date else audit_created end)
)
)
from audit
where general_audit_status = 'Abgeschlossen' and
assigned_auditor = 2