如何在报告结尾汇总所有透视生成的列(周末)值

时间:2017-03-14 12:35:23

标签: sql sql-server pivot pivot-table rollup

我已经生成了以下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 如何在表格的最后总结周末的所有价值。

1 个答案:

答案 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