我已经生成了以下SQL Server数据透视表,它给了我渴望的结果。我希望在枢轴结束时的周末专栏中添加所有技术人员工作的总数(周末和工作的小计),我发现这很难。
SELECT *
FROM
(
SELECT
ISNULL(FORMAT(( DATEADD(wk, DATEDIFF(wk, 0, DATEADD(dd,-1,J.JobDate)), 1) +5), 'dd/MM/yyyy'), 'Completed to Date') as Weekend
,U.Name + ' ' + U.Surname AS Technician
,(CASE WHEN U.Active = 1 THEN 'Active' ELSE 'Inactive' END ) AS Active
,COUNT(CASE WHEN SFS.FormId IN (66,69,68,79,94,72) THEN 1 ELSE NULL END) AS Total
FROM Jobs J
LEFT Join dbo.USERS_LIST_ALL() U ON
U.id = J.UserId
LEFT JOIN SimplyFormsSubmitted SFS ON
SFS.FormsSubmittedStatus = 'SUBMITTED'
AND SFS.JobId = J.id
AND SFS.DateSubmitted IS NOT NULL
WHERE
U.GroupId = 2 -- User Technician
AND J.DepartmentId = 132 -- Department
AND SFS.FormId IN (66,69,68,79,94,72)
GROUP BY
U.Active
,U.Name + ' ' + U.Surname
,ROLLUP(FORMAT(( DATEADD(wk, DATEDIFF(wk, 0, DATEADD(dd,-1,J.JobDate)), 1) +5), 'dd/MM/yyyy'))
) AS RefTable
pivot ( SUM(Total) for Weekend in (
[02/10/2016],
[09/10/2016],
[16/10/2016],
[23/10/2016],
[30/10/2016],
[06/11/2016],
[13/11/2016],
[20/11/2016],
[27/11/2016],
[04/12/2016],
[11/12/2016],
[18/12/2016],
[25/12/2016],
[01/01/2017],
[08/01/2017],
[15/01/2017],
[22/01/2017],
[29/01/2017],
[05/02/2017],
[12/02/2017],
[19/02/2017],
[26/02/2017],
[05/03/2017],
[12/03/2017],
[19/03/2017],
[Completed to Date]
)) as Answer
ORDER BY Answer.Active ASC
Here is generated result of the above query 如何在表格的最后总结周末的所有价值。
答案 0 :(得分:0)
我相信你需要类似于
的东西WITH your_query AS
(
SELECT *
FROM
(
SELECT
ISNULL(FORMAT(( DATEADD(wk, DATEDIFF(wk, 0, DATEADD(dd,-1,J.JobDate)), 1) +5), 'dd/MM/yyyy'), 'Completed to Date') as Weekend
,U.Name + ' ' + U.Surname AS Technician
,(CASE WHEN U.Active = 1 THEN 'Active' ELSE 'Inactive' END ) AS Active
,COUNT(CASE WHEN SFS.FormId IN (66,69,68,79,94,72) THEN 1 ELSE NULL END) AS Total
FROM Jobs J
LEFT Join dbo.USERS_LIST_ALL() U ON
U.id = J.UserId
LEFT JOIN SimplyFormsSubmitted SFS ON
SFS.FormsSubmittedStatus = 'SUBMITTED'
AND SFS.JobId = J.id
AND SFS.DateSubmitted IS NOT NULL
WHERE
U.GroupId = 2 -- User Technician
AND J.DepartmentId = 132 -- Department
AND SFS.FormId IN (66,69,68,79,94,72)
GROUP BY
U.Active
,U.Name + ' ' + U.Surname
,ROLLUP(FORMAT(( DATEADD(wk, DATEDIFF(wk, 0, DATEADD(dd,-1,J.JobDate)), 1) +5), 'dd/MM/yyyy'))
) AS RefTable
pivot ( SUM(Total) for Weekend in (
[02/10/2016],
[09/10/2016],
[16/10/2016],
[23/10/2016],
[30/10/2016],
[06/11/2016],
[13/11/2016],
[20/11/2016],
[27/11/2016],
[04/12/2016],
[11/12/2016],
[18/12/2016],
[25/12/2016],
[01/01/2017],
[08/01/2017],
[15/01/2017],
[22/01/2017],
[29/01/2017],
[05/02/2017],
[12/02/2017],
[19/02/2017],
[26/02/2017],
[05/03/2017],
[12/03/2017],
[19/03/2017],
[Completed to Date]
)) as Answer
)
SELECT * FROM your_query
UNION ALL
SELECT
'TOTAL',
null,
sum(isnull([02/10/2016],0)),
sum(isnull([09/10/2016],0)),
sum(isnull([16/10/2016],0)),
sum(isnull([23/10/2016],0)),
sum(isnull([30/10/2016],0)),
sum(isnull([06/11/2016],0)),
sum(isnull([13/11/2016],0)),
sum(isnull([20/11/2016],0)),
sum(isnull([27/11/2016],0)),
sum(isnull([04/12/2016],0)),
sum(isnull([11/12/2016],0)),
sum(isnull([18/12/2016],0)),
sum(isnull([25/12/2016],0)),
sum(isnull([01/01/2017],0)),
sum(isnull([08/01/2017],0)),
sum(isnull([15/01/2017],0)),
sum(isnull([22/01/2017],0)),
sum(isnull([29/01/2017],0)),
sum(isnull([05/02/2017],0)),
sum(isnull([12/02/2017],0)),
sum(isnull([19/02/2017],0)),
sum(isnull([26/02/2017],0)),
sum(isnull([05/03/2017],0)),
sum(isnull([12/03/2017],0)),
sum(isnull([19/03/2017],0)),
sum(isnull([Completed to Date],0))
FROM your_query
评论#2 UPD
我不确定它是否可以开箱即用,但您可以根据需要修改代码。
WITH step1 AS
(
SELECT
DATEADD(wk, DATEDIFF(wk, 0, DATEADD(dd,-1,J.JobDate)), 1)+5 as WeekendDate
,U.Name + ' ' + U.Surname AS Technician
,(CASE WHEN U.Active = 1 THEN 'Active' ELSE 'Inactive' END ) AS Active
,COUNT(CASE WHEN SFS.FormId IN (66,69,68,79,94,72) THEN 1 ELSE NULL END) AS Total
FROM Jobs J
LEFT Join dbo.USERS_LIST_ALL() U ON
U.id = J.UserId
LEFT JOIN SimplyFormsSubmitted SFS ON
SFS.FormsSubmittedStatus = 'SUBMITTED'
AND SFS.JobId = J.id
AND SFS.DateSubmitted IS NOT NULL
WHERE
U.GroupId = 2 -- User Technician
AND J.DepartmentId = 132 -- Department
AND SFS.FormId IN (66,69,68,79,94,72)
GROUP BY
U.Active
,U.Name + ' ' + U.Surname
,ROLLUP(DATEADD(wk, DATEDIFF(wk, 0, DATEADD(dd,-1,J.JobDate)), 1)+5)
),
RefTable AS
(
SELECT
ISNULL(FORMAT(WeekendDate, 'dd/MM/yyyy'), 'Completed to Date') as Weekend
,Technician
,Active
,avg(Total) over (
partition by Technician
order by WeekendDate desc
rows between current row and 3 following) as Avg4
,Total
FROM step1
),
your_query AS
(
SELECT *
FROM RefTable
pivot ( SUM(Total) for Weekend in (
[02/10/2016],
[09/10/2016],
[16/10/2016],
[23/10/2016],
[30/10/2016],
[06/11/2016],
[13/11/2016],
[20/11/2016],
[27/11/2016],
[04/12/2016],
[11/12/2016],
[18/12/2016],
[25/12/2016],
[01/01/2017],
[08/01/2017],
[15/01/2017],
[22/01/2017],
[29/01/2017],
[05/02/2017],
[12/02/2017],
[19/02/2017],
[26/02/2017],
[05/03/2017],
[12/03/2017],
[19/03/2017],
[Completed to Date]
)) as Answer
)
SELECT * FROM your_query
UNION ALL
SELECT
'TOTAL',
null,
null,
sum(isnull([02/10/2016],0)),
sum(isnull([09/10/2016],0)),
sum(isnull([16/10/2016],0)),
sum(isnull([23/10/2016],0)),
sum(isnull([30/10/2016],0)),
sum(isnull([06/11/2016],0)),
sum(isnull([13/11/2016],0)),
sum(isnull([20/11/2016],0)),
sum(isnull([27/11/2016],0)),
sum(isnull([04/12/2016],0)),
sum(isnull([11/12/2016],0)),
sum(isnull([18/12/2016],0)),
sum(isnull([25/12/2016],0)),
sum(isnull([01/01/2017],0)),
sum(isnull([08/01/2017],0)),
sum(isnull([15/01/2017],0)),
sum(isnull([22/01/2017],0)),
sum(isnull([29/01/2017],0)),
sum(isnull([05/02/2017],0)),
sum(isnull([12/02/2017],0)),
sum(isnull([19/02/2017],0)),
sum(isnull([26/02/2017],0)),
sum(isnull([05/03/2017],0)),
sum(isnull([12/03/2017],0)),
sum(isnull([19/03/2017],0)),
sum(isnull([Completed to Date],0))
FROM your_query