1

我试图在我的 PIVOT 表中获取 2 个或更多 TIME 字段的 SUM,但是因为 SUM 不适用于字符(已转换以便我可以显示 EstimatedTime / ActualTime),所以我遇到了困难。

下面的代码 -

DECLARE @cols AS NVARCHAR(MAX);
DECLARE @query AS NVARCHAR(MAX);

select @cols = STUFF((SELECT distinct ',' + ID + ',' + QUOTENAME(Name)
                  FROM JobPhases
                  FOR XML PATH(''), TYPE
                 ).value('.', 'NVARCHAR(MAX)') 
                    , 1, 1, '');

SELECT @query = 'SELECT * FROM    
(   
    SELECT j.JobID, c.Registration as ''Reg.'', p.Name, 
    CAST(MAX(j.EstimatedTime) as VARCHAR(MAX)) + ''/'' +
    CAST(MAX(j.ActualTime) as VARCHAR(MAX)) as [x]
    FROM    JobDetails  AS j
    INNER JOIN JobPhases p ON p.ID = j.PhaseId
    INNER JOIN Jobs job on job.ID = j.JobID
    INNER JOIN Cars c on job.CarID = c.ID
    WHERE (job.Status = 1 or job.Status = 0)
    GROUP BY c.Registration, p.Name, j.JobID
) JobDetails
PIVOT
(   MAX(x)
    FOR Name IN (' + @cols + ')
) pvt'

execute(@query);

生成 -

JobID | Reg.     | P13$ | Repair and Reshape                | P15$ | Refit Stripped Parts
1065  | BJ11 2VT | NULL | 01:00:00.0000000/01:54:10.5387526 | NULL | NULL

表 -

**JobDetails**
ID - PK Auto increment
JobID - Int (Joined to Jobs table)
PhaseID - String (joined to JobPhases table)
EstimatedTime - time(7)
ActualTime time(7)

**JobPhases****
ID - PK String
Name - VarChar(150)

此示例中的问题是 JobID 1065 有 2 个 JobDetails -

ID | JobID | PhaseID | EstimatedTime    | ActualTime 
25 | 1065  | P13$    | 01:00:00.0000000 | 01:54:10.5387526
26 | 1065  | P13$    | 00:30:00.0000000 | 00:00:00.0000000

所以,正确的结果应该是(注意修复和重塑中的 1:30)-

JobID | Reg.     | P13$ | Repair and Reshape                | P15$ | Refit Stripped Parts
1065  | BJ11 2VT | NULL | 01:30:00.0000000/01:54:10.5387526 | NULL | NULL

有什么想法可以获取每个阶段 id 的所有行的总 EstimatedTime 吗?

谢谢!

4

1 回答 1

1

对列求和TIME并不简单,您需要的是重写您的行;

CAST(MAX(j.EstimatedTime) as VARCHAR(MAX)) + ''/'' +

类似于(未经测试的)

CAST(CAST(DATEADD(ms, SUM(DATEDIFF(ms, '0:00:00', j.EstimatedTime)), 
                 '00:00:00') AS TIME) AS VARCHAR(MAX)) + ''/'' +
于 2013-07-29T10:41:57.743 回答