首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Using Count with Case语句(T-SQL)

Using Count with Case语句(T-SQL)
EN

Stack Overflow用户
提问于 2018-05-31 07:18:20
回答 1查看 38关注 0票数 0

下面的查询生成以下错误消息:“无法对包含聚合或子查询的表达式执行聚合函数。”

我正在尝试从一个表中获取元素(贷款)的计数,该计数基于我已放入case语句中的特定条件。我使用了case语句,而不是简单地将条件插入WHERE子句中,因为我用这个查询提取了多个指标,而这些条件只适用于这个特定的指标,而不适用于其他指标。我怎么才能修复它?

代码语言:javascript
复制
SELECT COUNT(
     CASE
          WHEN (SELECT CONVERT(DATE, MAX(Dates)) FROM (VALUES (S.SchedClosingDate), (S.SchedClosingDate)) AS SchedDates (Dates)) BETWEEN '05/01/18' AND '05/31/18' THEN FD.FileName
     END
     ) AS [Scheduled to Close]
FROM FileData AS FD
JOIN Status AS S ON FD.FileDataID = S.FileDataID

注意:为了提高可读性,我从查询中删除了其他指标。

EN

回答 1

Stack Overflow用户

发布于 2018-05-31 07:23:23

使用APPLY将计算移动到FROM子句

代码语言:javascript
复制
SELECT SUM(CASE WHEN v.dte >= '2018-05-01' AND v.dte < '2018-06-01' AND
                     FD.FileName IS NOT NULL
                THEN 1 ELSE 0 END
           END) AS [Scheduled to Close]
FROM FileData FD JOIN
     Status S
     ON FD.FileDataID = S.FileDataID CROSS APPLY
     (SELECT MAX(dte)
      FROM (VALUES (S.SchedClosingDate), (S.SchedClosingDate)) SchedDates(dte)
     ) as v(dte);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50614557

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档