2 b qxzb B_qxzb 于 2015.06.18 14:40 提问

oracle,按任务单完成状态来统计每个人的任务单数量?

1.任务单表(taskinfo),字段有:计划完成日期(enddate),实际完成日期(factenddate),用户名(username)等

2.按任务单完成状态来统计每个人每月的任务单数量
说明:任务单完成状态,是由实际完成日期与计划完成日期比较得来的,
1)实际完成日期小于计划完成日期,表示提前完成
2)等于,表示按时完成
3)大于,表示延期完成

3.最后的统计结果应该是,
用户名 提前完成 按时完成 延期完成
XXX 数量 数量 数量
XXX 数量 数量 数量
XXX 数量 数量 数量
……

2个回答

danielinbiti
danielinbiti   Ds   Rxr 2015.06.18 15:18
已采纳
 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
syjgreen07
syjgreen07   2015.06.18 16:45

用decode和sum省时省力!

syjgreen07
syjgreen07 回复WolfySein: decode 看你怎么用了.
2 年多之前 回复
WolfySein
WolfySein decode是等于 不能大于和小于
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片