1.任务单表(taskinfo),字段有:计划完成日期(enddate),实际完成日期(factenddate),用户名(username)等
2.按任务单完成状态来统计每个人每月的任务单数量
说明:任务单完成状态,是由实际完成日期与计划完成日期比较得来的,
1)实际完成日期小于计划完成日期,表示提前完成
2)等于,表示按时完成
3)大于,表示延期完成
3.最后的统计结果应该是,
用户名 提前完成 按时完成 延期完成
XXX 数量 数量 数量
XXX 数量 数量 数量
XXX 数量 数量 数量
……
select username,sum(大于数量) 大于数量,sum(等于数量) 等于数量,sum(小于数量) 小于数量 from
(
select username
,case when enddate>factenddate then 1 else 0 end 大于数量
,case when enddate=factenddate then 1 else 0 end 等于数量
,case when enddate<factenddate then 1 else 0 end 小于数量
from taskinfo
) group by username
用decode和sum省时省力!