[英]SSRS - Why isn't my SUM() working correctly?
我遵循了 techonthenet 上的指南,其中说对于 SUM 查询,您需要将Sum(expr)
放在SELECT
语句中,然后对您选择的所有其他字段进行GROUP BY
(伪代码;如果我错了,请纠正我) . 下面是我的尝试。 为什么我收到错误
“执行查询时出错。'(' 附近的语法不正确。错误:102;第 9 行”
所有这一切的最终结果将是一个报告,而不仅仅是一个查询。 在报告中,下面的所有字段都将显示,但 [差异] 字段将在底部汇总。 我觉得与其在查询中求和,不如在报告中求和...
编辑- 我删除了 [ALL] 但现在我收到错误“不能在用于 group by 子句列表的表达式中使用聚合或子查询。” 它还说这个错误在第 29 行。我会在下面标记它。
SELECT
JOB.WHSE,
LEFT(RESSCHD000.RESID, 6) AS Line,
RIGHT(LEFT(JOB000.JSID, 11), 10)+ '-' +RIGHT(LEFT(JOB000.JSID, 27), 2) AS [Job Number],
LEFT(RESSCHD000.STARTDATE, 7)+ ' ' +RIGHT(Convert(Datetime, MIN(RESSCHD000.STARTDATE)), 8) AS [Start],
LEFT(RESSCHD000.ENDDATE, 7)+ ' ' +RIGHT(Convert(Datetime, MAX(RESSCHD000.ENDDATE)),8) AS [End],
RESSCHD000.STATUSCD,
Sum((Dateadd("n",DateDiff("n", MIN(RESSCHD000.STARTDATE),MAX(RESSCHD000.ENDDATE)),'00:00:00'))) AS [SumOfDifference],
RESSCHD000.JOBTAG,
CASE
WHEN Dateadd("n",DateDiff("n", MIN(RESSCHD000.STARTDATE),MAX(RESSCHD000.ENDDATE)),'00:00:00') > '3:59:00'
THEN 'Full Sanitation'
ELSE 'Dry Clean'
END AS [Type of Sanitation],
jrt_sch.Uf_Quoted_Crew_Size AS [Crew Size]
FROM
RESSCHD000 INNER JOIN JOB000 ON RESSCHD000.JOBTAG = JOB000.JOBTAG
INNER JOIN JOB ON JOB.JOB = RIGHT(LEFT(JOB000.JSID, 11), 10) AND JOB.suffix = RIGHT(LEFT(JOB000.JSID, 27), 2)
LEFT OUTER JOIN jrt_sch ON jrt_sch.job = job.job
WHERE
job.job_date = @job_date
GROUP BY
JOB.WHSE,
LEFT(RESSCHD000.RESID, 6),
RIGHT(LEFT(JOB000.JSID, 11), 10)+ '-' +RIGHT(LEFT(JOB000.JSID, 27), 2), --line 29
LEFT(RESSCHD000.STARTDATE, 7)+ ' ' +RIGHT(Convert(Datetime, MIN(RESSCHD000.STARTDATE)), 8),
LEFT(RESSCHD000.ENDDATE, 7)+ ' ' +RIGHT(Convert(Datetime, MAX(RESSCHD000.ENDDATE)),8),
RESSCHD000.STATUSCD,
RESSCHD000.JOBTAG,
CASE
WHEN Dateadd("n",DateDiff("n", MIN(RESSCHD000.STARTDATE),MAX(RESSCHD000.ENDDATE)),'00:00:00') > '3:59:00'
THEN 'Full Sanitation'
ELSE 'Dry Clean'
END,
jrt_sch.Uf_Quoted_Crew_Size
HAVING
RESSCHD000.STATUSCD='s'
错误是由于这一行:
Sum([ALL] (Dateadd("n",DateDiff("n", MIN(RESSCHD000.STARTDATE),MAX(RESSCHD000.ENDDATE)),'00:00:00'))) AS [SumOfDifference]
总和正在寻找一个字段(或某种公式)来求和。 您有一个字段名称,后跟一个公式。 我猜您想要基于 FIELD 名称 (SumOfDifference) 的秒差总和。
我认为您只需要删除[ALL] 。
SUM(DATEADD("n",DATEDIFF("n", MIN(RESSCHD000.STARTDATE), MAX(RESSCHD000.ENDDATE)),'00:00:00')) AS [SumOfDifference]
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.