2010-08-19 70 views
1

我想顯示每個用戶花了他們的時間做一週(內部或外部工作),但時間都在表上的同一列,是否有可能分裂它分成2個不同的列,並且仍然具有這樣的功能,因此它只顯示每個用戶一次不是每次輸入時間,而這一次可能在整個星期內多次。矛盾的問題在哪裏條款

下面的SQL給我每個用戶跟蹤一週的時間,但不同行的內部和外部。

SELECT SUM(FilteredMag_Time.mag_hoursspent) AS Time, 
     FilteredSystemUser.fullname, 
     FilteredMag_project.mag_typename 
    FROM FilteredSystemUser 
INNER JOIN FilteredMag_Task 
INNER JOIN FilteredMag_project ON FilteredMag_Task.mag_projectid = FilteredMag_project.mag_projectid 
INNER JOIN FilteredMag_Time ON FilteredMag_Task.mag_taskid = FilteredMag_Time.mag_taskid 
          ON FilteredSystemUser.systemuserid = FilteredMag_Time.createdby 
    WHERE (FilteredMag_Time.mag_starttime BETWEEN DATEADD(dd, - (DATEPART(dw, GETDATE()) - 1), GETDATE()) 
               AND DATEADD(dd, - (DATEPART(dw, GETDATE()) - 7), GETDATE())) 
GROUP BY FilteredSystemUser.fullname, FilteredMag_project.mag_typename 
ORDER BY FilteredSystemUser.fullname 

以下是當前輸出示例。

Time    fullname    mag_typename 
------------------ --------------------- ------------------------- 
1.2500000000  David Sutton  External 
8.2500000000  Gayan Perera  External 
9.0000000000  Paul Nieuwelaar  Internal 
14.8700000000  Roshan Mehta  External 
6.0000000000  Roshan Mehta  Internal 
2.7800000000  Simon Phillips  External 
4.6600000000  Simon Phillips  Internal 
+1

你能提供的示例數據和預期輸出? – 2010-08-19 04:27:13

回答

0

假設FilteredMag_project.mag_typename是 '內部' 或 '外部',請嘗試以下操作:

SELECT SUM(CASE FilteredMag_project.mag_typename 
       WHEN 'INTERNAL' THEN FilteredMag_Time.mag_hoursspent 
       ELSE 0 END) AS InternalTime, 
     SUM(CASE FilteredMag_project.mag_typename 
       WHEN 'EXTERNAL' THEN FilteredMag_Time.mag_hoursspent 
       ELSE 0 END) AS ExternalTime, 
     FilteredSystemUser.fullname 
    FROM FilteredSystemUser 
INNER JOIN FilteredMag_Task 
INNER JOIN FilteredMag_project ON FilteredMag_Task.mag_projectid = FilteredMag_project.mag_projectid 
INNER JOIN FilteredMag_Time ON FilteredMag_Task.mag_taskid = FilteredMag_Time.mag_taskid 
          ON FilteredSystemUser.systemuserid = FilteredMag_Time.createdby 
    WHERE (FilteredMag_Time.mag_starttime BETWEEN DATEADD(dd, - (DATEPART(dw, GETDATE()) - 1), GETDATE()) 
               AND DATEADD(dd, - (DATEPART(dw, GETDATE()) - 7), GETDATE())) 
GROUP BY FilteredSystemUser.fullname 
ORDER BY FilteredSystemUser.fullname 
1

您可以使用SQL Server PIVOT

喜歡的東西

DECLARE @Table TABLE(
     userID INT, 
     typeID VARCHAR(20), 
     TimeSpent FLOAT 
) 

INSERT INTO @Table SELECT 1, 'INTERNAL', 1 
INSERT INTO @Table SELECT 2, 'INTERNAL', 1 
INSERT INTO @Table SELECT 1, 'INTERNAL', 1 
INSERT INTO @Table SELECT 1, 'INTERNAL', 1 
INSERT INTO @Table SELECT 2, 'EXTERNAL', 3 
INSERT INTO @Table SELECT 1, 'EXTERNAL', 3 

SELECT * 
FROM 
(
    SELECT userID, typeID, TimeSpent 
    FROM @Table 
) s 
PIVOT (SUM(TimeSpent) FOR typeID IN ([INTERNAL],[EXTERNAL])) pvt 

輸出:

userID  INTERNAL    EXTERNAL 
----------- ---------------------- ---------------------- 
1   3      3 
2   1      3 
+0

+1最後一個例子,即使我明白PIVOT。 – 2010-08-19 08:29:18

+0

這看起來像它會做我以後的事情,但由於我仍然是SQL新手,我無法弄清楚如何使它工作。 – Simon 2010-08-19 21:37:04

+0

那很好。我們都在某處開始...... X-) – 2010-08-20 04:40:03