0
我有表INCIDENT
与行SQL百分比
TICKETID ACTUALFINISH TARGETFINISH
100 2012-03-01 11:11:11 2012-02-01 11:11:11
101 2012-03-01 11:11:11 2012-01-01 11:11:11
102 2012-04-01 11:11:11 2012-06-01 11:11:11
103 2012-05-01 11:11:11 2012-07-01 11:11:11
104 null null
我想在行的百分比,其中target finish
比actual finish
和相对较大。
因此,对于这个表的结果将是(不涉及空值):
SLA PERCENTAGE
YES 50
NO 50
我写的SQL查询,但我不断收到错误。我不知道错误在哪里。
我第一次得到的不是地方AFIS比TF大的记录总数,然后AF比TF
with HELPTABLE as
(select count(*) as Total
from incident as incident4
where incident4.targetfinish is not null and incident4.actualfinish is not null)
select distinct case when incident.targetfinish>incident.actualfinish then
dec(((select count(*)
from incident as incident1
where incident1.targetfinish is not null and incident1.actualfinish is not null )),10,2)/HELPTABLE.Total*100
when incident.targetfinish<incident.actualfinish then
dec(((select count(*)
from incident as incident2
where incident2.targetfinish is not null and incident2.actualfinish is not null )),10,2)/HELPTABLE.Total*100
end as Percentage,
case when incident.targetfinish>incident.actualfinish then 'Yes'
when incident.targetfinish<incident.actualfinish then 'No'
end as SLA
from incident
where incident.targetfinish is not null and incident.actualfinish is not null
如果有人知道什么是错误的感谢小!
[Error Code: -206, SQL State: 42703] DB2 SQL Error: SQLCODE=-206, SQLSTATE=42703, SQLERRMC=HELPTABLE.TOTAL, DRIVER=3.57.82)
谢谢,但我不断收到0回报此值。我尝试只选择'是'作为SLA, (SUM(当targetfinish> actualfinish然后1 else 0结束时)/ count(*))* 100作为PERCENTAGE 来自事件 其中targetfinish不为null且actualfinish不为null我得到0回报? – Dejan
这不行。 SQL中缺少什么? – Dejan
@Dejan右键,我编辑:把1.0(和0,0)或者分配一个分区的一部分,因为float会起作用。如果你不这样做,它是一个整数除法,并且在整数中,2/5 = 0 –