ISNULL() 不起作用.可能是错误的放置



以下查询在它之外工作得很好,仍然返回空值作为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 

最新更新