-1

我必须将旧查询更改为新查询才能获得正确的结果。我的旧查询曾经在分母中返回空值,所以我不必担心除以零,新查询返回除我的零作为“M”(R_NTWK_CHNNL),但对于“S”或 R,我不'没有零分母。我该怎么做才能在查询 2 中获得空分母?表定义没有改变,并且想知道为什么现在当“M”中没有任何内容时我没有得到空分母。还请,我将如何添加nullif到查询2?非常感谢你。

旧查询

select SUM(CASE WHEN (GNRC_CD in ('O') and  R_NTWK_CHNNL = 'M')  then (CLNT_NET_DUE_AMT + NBNR_CLNT_NET_DUE_AMT) else 0 end ) / sUM(CLMS) from #Clms_SMRY where  SRVC_DT  between @CurrentBeginDate and @CurrentEndDate)

新查询

select SUM(CASE WHEN (GNRC_CD in ('O') ) and R_NTWK_CHNNL =  'M'  then (CLNT_NET_DUE_AMT + NBNR_CLNT_NET_DUE_AMT) else 0 end ) / cast(SUM(CASE WHEN GNRC_CD in ('O') and R_NTWK_CHNNL =  'M' then (CLMS)  end ) as float) from #Clms_Smry where  SRVC_DT  between @CurrentBeginDate and @CurrentEndDate),
4

1 回答 1

0

使用NULLIF()

select (SUM(CASE WHEN (GNRC_CD in ('O') and R_NTWK_CHNNL = 'M') then (CLNT_NET_DUE_AMT + NBNR_CLNT_NET_DUE_AMT) else 0 end ) / 
        NULLIF(SUM(CLMS), 0)
       ) 
from #Clms_SMRY
where SRVC_DT between @CurrentBeginDate and @CurrentEndDate)
于 2020-09-02T22:42:03.360 回答