使用以下查询对整个列求和。在TOREMOVEALLPRIV列中,我有整数和空值。 我想将null和整数值相加并打印总和值。
这是我的查询,它将和值打印为空。
select
sum(URT.PRODSYS) as URT_SUM_PRODSYS,
sum(URT.Users) as URT_SUM_USERS,
sum(URT.total_orphaned) as URT_SUM_TOTAL_ORPHANED,
sum(URT.Bp_errors) as URT_SUM_BP_ERRORS,
sum(URT.Ma_errors) as URT_SUM_MA_ERRORS,
sum(URT.Pp_errors) as URT_SUM_PP_ERRORS,
sum(URT.REQUIREURTCBN) as URT_SUM_CBNREQ,
sum(URT.REQUIREURTQEV) as URT_SUM_QEVREQ,
sum(URT.REQUIREURTPRIV) as URT_SUM_PRIVREQ,
sum(URT.cbnperf) as URT_SUM_CBNPERF,
sum(URT.qevperf) as URT_SUM_QEVPERF,
sum(URT.privperf) as URT_SUM_PRIVPERF,
sum(URT.TO_REMOVEALLPRIV) as TO_REMOVEALLPRIV_SUM
from
URTCUSTSTATUS URT
inner join CUSTOMER C on URT.customer_id=C.customer_id;
输出图片:
预期的输出:
而不是null我需要打印具有整数的行的总和。
答案 0 :(得分:1)
SUM
功能会自动为您处理。你说这个专栏混合了NULL
和数字; SUM
会自动忽略NULL
值并正确返回数字的总和。您可以在IBM Knowledge Center上阅读:
该函数应用于通过消除空值从参数值派生的值集。
注意:除NULL
函数外,所有聚合函数都忽略COUNT
个值。示例:如果您有两条值为5
和NULL
的记录,则SUM
和AVG
函数都将返回5
,但COUNT
函数将返回2
。
然而,您似乎误解了为什么您获得NULL
的结果。它是坚果,因为该列包含null
值,因为没有选择记录。这是SUM
函数返回NULL
时唯一的情况。如果您想在这种情况下返回零,则可以使用COALESCE
或IFNULL
函数。这两种情况都是相同的:
COALESCE(sum(URT.TO_REMOVEALLPRIV), 0) as TO_REMOVEALLPRIV_SUM
或
IFNULL(sum(URT.TO_REMOVEALLPRIV), 0) as TO_REMOVEALLPRIV_SUM
我猜你想对查询中的所有其他列做同样的事情,所以我不确定为什么你只抱怨TO_REMOVEALLPRIV
列。
答案 1 :(得分:0)
您正在寻找的是COALESCE
功能:
select
sum(URT.PRODSYS) as URT_SUM_PRODSYS,
sum(URT.Users) as URT_SUM_USERS,
sum(URT.total_orphaned) as URT_SUM_TOTAL_ORPHANED,
sum(URT.Bp_errors) as URT_SUM_BP_ERRORS,
sum(URT.Ma_errors) as URT_SUM_MA_ERRORS,
sum(URT.Pp_errors) as URT_SUM_PP_ERRORS,
sum(URT.REQUIREURTCBN) as URT_SUM_CBNREQ,
sum(URT.REQUIREURTQEV) as URT_SUM_QEVREQ,
sum(URT.REQUIREURTPRIV) as URT_SUM_PRIVREQ,
sum(URT.cbnperf) as URT_SUM_CBNPERF,
sum(URT.qevperf) as URT_SUM_QEVPERF,
sum(URT.privperf) as URT_SUM_PRIVPERF,
sum(COALESCE(URT.TO_REMOVEALLPRIV,0)) as TO_REMOVEALLPRIV_SUM
from
URTCUSTSTATUS URT
inner join CUSTOMER C on URT.customer_id=C.customer_id;