以下查询在它之外工作得很好,仍然返回空值作为NULL
而不是0
。具体来说,这是总结指定日期范围内某事发生的次数。如果该值在参数中不存在(即 NULL
,) 那么为了可读性,我希望它返回一个 0(该表是多个临时表的连接,仅包含整数。我已经研究并发现了这种情况"从SQL函数获取单个值时如何将NULL更改为0?"并尝试了那里的所有建议,包括COALESCE
。
(SELECT tn.teamtext, tn.teamid, ISNULL(sum(ISNULL(case when CONVERT(smalldatetime,ca.dModLast,101) BETWEEN '2012-03-01' AND '2012-03-10' then 1 else 0 end, 0)), 0) AS cnt3
FROM teamnames AS tn
LEFT OUTER JOIN caseaudit AS ca
ON tn.teamID = ca.referteamID2
WHERE ca.referteamid1 <> ca.referteamid2 AND ca.isactive = 1 AND ca.groupid = 18 AND ca.accountid = 2 AND ca.referteamid1 = 31 AND ca.auditnote <> 'Suspend Case'
GROUP BY tn.teamtext, tn.teamid) AS c
为了给出我正在查看的返回表的想法,这里是:
4H BOSS 55 59 3
4H BSG 0 3 2
4H SALES AND MKTG 0 0 0
ACCOUNTS RECEIVABLE 0 0 0
ASSET MANAGEMENT 9 16 0
AUDIT 0 0 NULL
BOSS 4 5 0
CORPORATE BSG 0 7 5
CUSTOMER SUPPORT 87 133 NULL
NETWORK ENGINEERING 11 15 0
PRODUCTION ENGINEERING 116 142 5
PRODUCTION OPERATIONS 0 1 0
SECURITY 2 6 3
SNFAL PRODUCT TEAM 0 14 11
VOICE SERVICES 18 21 0
XEROX 4 8 0
我同意(到目前为止)另外两个响应 - 此查询中的 NULL 逻辑应该像您所说的那样工作。但。。。
我在本地表上运行了类似于您的查询的内容,一切运行正常。然后我添加了最外面的参数:
(SELECT...
...) AS c
并收到错误,因为 SQL 不支持该格式。结合您的示例显示查询中仅列出三列的四列,让我强烈怀疑这是较大查询中的子查询......在这种情况下,null/not null 问题可能纠结于完整查询的逻辑,而不仅仅是这个子查询。如果我的猜测是正确的,请发布完整的查询供我们考虑。
更改为
ISNULL(SUM(CASE WHEN ISNULL(ca.dModLast,0)=0 THEN 0 ELSE CASE WHEN CONVERT(smalldatetime,ca.dModLast,101) BETWEEN '2012-03-01' AND '2012-03-10' THEN 1 ELSE 0 END END),0) as cnt3
我假设由于CONVERT(smalldatetime,dModLast,101) BETWEEN '2012-03-01' AND '2012-03-10'
引用了正确的表,有时它可以计算为 NULL,而情况没有得到它。
你能尝试明确地做when (dModLast is null) then 0
编辑:
case
when dModLast is null then 0
when CONVERT(smalldatetime,dModLast,101) BETWEEN '2012-03-01' AND '2012-03-10' then 1
else 0
end