2013-03-11 126 views
6

我試圖通過與SQL查詢做了一個先進的訂單高級SQL Server的訂購

我有一個用來跟蹤工作流程及其相關活動

以前的活動(已完成的)數據庫處於closed狀態。他們同時擁有Active_DateClosed_Date集合

當前活動處於active狀態。有一個Active_Date集,但Closed_DateNULL

對於每個ECR.item_number只會出現在active狀態的一個活動

我想通過

  1. ECR.item_number訂購,但我想爲了根據active狀態中哪個活動降序排列
  2. A.ACTIVE_DATE

查詢:

SELECT 
    ECR.item_number, 
    ECR.title, 
    convert(VARCHAR(10),ECR.CREATED_ON,120) AS [Date CR Created], 
    convert(VARCHAR(10),A.ACTIVE_DATE,120) AS [Activity Activated], 
    convert(VARCHAR(10),A.CLOSED_DATE,120) AS [Activity Closed], 
    A.STATE, 
    A.NAME AS [Activity Name], 

    (CASE 
     WHEN 
      (A.STATE='Closed') 
     THEN 
      DATEDIFF(DAY, A.ACTIVE_DATE, A.CLOSED_DATE)  
    END) AS [DAYS ACTIVITY (WAS) OPEN], 

    (CASE 
     WHEN 
      (A.STATE='Active') 
     THEN 
      DATEDIFF(DAY, A.ACTIVE_DATE, Getdate()) 
    END) AS [DAYS ACTIVITY HAS BEEN OPEN] 

FROM 
    innovator.ecr AS ECR 
    INNER JOIN innovator.workflow AS WF 
     ON CR.id = WF.source_id 
    INNER JOIN innovator.workflow_process AS WFP 
     ON WF.related_id = WFP.id 
    INNER JOIN innovator.workflow_process_activity AS WPA 
     ON WFP.id = WPA.source_id 
    INNER JOIN innovator.activity AS A 
     ON WPA.related_id = A.id 

--Shown for clarity 
ORDER BY 
    ECR.ITEM_NUMBER, 
    [Activity Activated] 

採樣返回數據

|-----------+-----------+-------------------+-----------------------+-----------------------+-------------------+-------------------------------+-------------------------------| 
|CR Number | Title | Date CR Created | Activity Name  | Activity Activated | Activity Closed | DAYS ACTIVITY (WAS) OPEN | DAYS ACTIVITY HAS BEEN OPEN | 
|-----------+-----------+-------------------+-----------------------+-----------------------+-------------------+-------------------------------+-------------------------------| 
|CR-000119 | ITEM 1 | 4/12/2012  | Submit CR   | 4/12/2012   | 31/01/2013  | 58       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | Check CR   | 31/01/2013   | 13/02/2013  | 13       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | Review CR   | 13/02/2013   | 21/02/2013  | 8       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | Technical Review | 21/02/2013   | 28/02/2013  | 7       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | CRB Meeting   | 28/02/2013   | NULL   | NULL      | 11       | 
|CR-00| ITEM 2 | 6/12/2012  | Check CR   | 6/12/2012   | 21/12/2012  | 15       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | Submit CR   | 6/12/2012   | 6/12/2012  | 0       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | Review CR   | 21/12/2012   | 17/01/2013  | 27       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | Technical Review | 17/01/2013   | 6/03/2013  | 48       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | CRB Meeting   | 6/03/2013   | NULL   | NULL      | 5       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Submit CR   | 11/01/2013   | 15/01/2013  | 4       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Check CR   | 15/01/2013   | 16/01/2013  | 1       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Review CR   | 16/01/2013   | 21/01/2013  | 5       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Technical Review | 21/01/2013   | 25/01/2013  | 4       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | CRB Meeting   | 25/01/2013   | 31/01/2013  | 6       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Technical Review | 31/01/2013   | 27/02/2013  | 27       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | CRB Meeting   | 27/02/2013   | NULL   | NULL      | 12       | 
|-----------+-----------+-------------------+-----------------------+-----------------------+-------------------+-------------------------------+-------------------------------| 

所需的結果

|-----------+-----------+-------------------+-----------------------+-----------------------+-------------------+-------------------------------+-------------------------------| 
|CR Number | Title | Date CR Created | Activity Name  | Activity Activated | Activity Closed | DAYS ACTIVITY (WAS) OPEN | DAYS ACTIVITY HAS BEEN OPEN | 
|-----------+-----------+-------------------+-----------------------+-----------------------+-------------------+-------------------------------+-------------------------------| 
|CR-000136 | ITEM 3 | 11/01/2013  | Submit CR   | 11/01/2013   | 15/01/2013  | 4       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Check CR   | 15/01/2013   | 16/01/2013  | 1       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Review CR   | 16/01/2013   | 21/01/2013  | 5       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Technical Review | 21/01/2013   | 25/01/2013  | 4       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | CRB Meeting   | 25/01/2013   | 31/01/2013  | 6       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | Technical Review | 31/01/2013   | 27/02/2013  | 27       | 0       | 
|CR-000136 | ITEM 3 | 11/01/2013  | CRB Meeting   | 27/02/2013   | NULL   | NULL      | 12       | 
|CR-000119 | ITEM 1 | 4/12/2012  | Submit CR   | 4/12/2012   | 31/01/2013  | 58       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | Check CR   | 31/01/2013   | 13/02/2013  | 13       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | Review CR   | 13/02/2013   | 21/02/2013  | 8       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | Technical Review | 21/02/2013   | 28/02/2013  | 7       | 0       | 
|CR-000119 | ITEM 1 | 4/12/2012  | CRB Meeting   | 28/02/2013   | NULL   | NULL      | 11       | 
|CR-00| ITEM 2 | 6/12/2012  | Check CR   | 6/12/2012   | 21/12/2012  | 15       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | Submit CR   | 6/12/2012   | 6/12/2012  | 0       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | Review CR   | 21/12/2012   | 17/01/2013  | 27       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | Technical Review | 17/01/2013   | 6/03/2013  | 48       | 0       | 
|CR-00| ITEM 2 | 6/12/2012  | CRB Meeting   | 6/03/2013   | NULL   | NULL      | 5       | 
|-----------+-----------+-------------------+-----------------------+-----------------------+-------------------+-------------------------------+-------------------------------| 

回答

2

在這種情況下,我覺得ECR.item_number處於活躍狀態,並指定這個日期到整個組ECR.item_number通過MAX()OVER()子句。在SELECT語句中,對新列進行進一步排序(升序),其位置爲10。您也可以在SELECT語句

SELECT ECR.item_number, 
     ECR.title, 
     convert(VARCHAR(10),ECR.CREATED_ON,120) AS [Date CR Created], 
     convert(VARCHAR(10),A.ACTIVE_DATE,120) AS [Activity Activated], 
     convert(VARCHAR(10),A.CLOSED_DATE,120) AS [Activity Closed], 
     A.STATE, 
     A.NAME AS [Activity Name], 
    (CASE WHEN (A.STATE='Closed') 
      THEN DATEDIFF(DAY, A.ACTIVE_DATE, A.CLOSED_DATE)  
    END) AS [DAYS ACTIVITY (WAS) OPEN], 
    (CASE WHEN (A.STATE='Active') 
     THEN DATEDIFF(DAY, A.ACTIVE_DATE, Getdate()) 
    END) AS [DAYS ACTIVITY HAS BEEN OPEN], 
    MAX(CASE WHEN A.CLOSED_DATE IS NULL THEN A.ACTIVE_DATE END) OVER (PARTITION BY ECR.item_number) 
FROM innovator.ecr AS ECR 
    INNER JOIN innovator.workflow AS WF 
     ON CR.id = WF.source_id 
    INNER JOIN innovator.workflow_process AS WFP 
     ON WF.related_id = WFP.id 
    INNER JOIN innovator.workflow_process_activity AS WPA 
     ON WFP.id = WPA.source_id 
    INNER JOIN innovator.activity AS A 
     ON WPA.related_id = A.id 
ORDER BY 10 ASC, ECR.ITEM_NUMBER, A.ACTIVE_DATE ASC 

簡單的演示使用上SQLFiddle

+0

非常感謝你,這個偉大的工程 – Spacko 2013-03-11 10:22:58

+0

你」對於一個好問題,歡迎..thx;) – 2013-03-11 10:32:21

2

別名作爲排序列,而不是10位上數這裏的關鍵是讓每個項目的Active活動的日期。這可以通過使用分析函數來完成:

[DateOfActiveActivity] = MIN(CASE WHEN A.CLOSED_DATE IS NULL THEN A.ACTIVE_DATE END) OVER(PARTITION BY ECR.item_number) 

所以這個集成到您查詢,您可以使用:

WITH CTE AS 
( SELECT [CRNumber] = ECR.item_number, 
      ECR.title, 
      [DateCRCreated] = CAST(ECR.CREATED_ON AS DATE), 
      [ActivityActivated] = CAST(A.ACTIVE_DATE AS DATE), 
      [ActivityClosed] = CAST(A.CLOSED_DATE AS DATE), 
      A.STATE, 
      [ActivityName] = A.NAME, 
      [DAYSACTIVITYOPEN] = CASE WHEN A.STATE = 'Closed' THEN DATEDIFF(DAY, A.ACTIVE_DATE, A.CLOSED_DATE) END, 
      [DAYSACTIVITYHASBEENOPEN] = CASE WHEN A.STATE = 'Active' THEN DATEDIFF(DAY, A.ACTIVE_DATE, GETDATE()) END, 
      [DateOfActiveActivity] = MIN(CASE WHEN A.CLOSED_DATE IS NULL THEN A.ACTIVE_DATE END) OVER(PARTITION BY ECR.item_number) 
    FROM innovator.ecr AS ECR 
      INNER JOIN innovator.workflow AS WF 
       ON CR.id = WF.source_id 
      INNER JOIN innovator.workflow_process AS WFP 
       ON WF.related_id = WFP.id 
      INNER JOIN innovator.workflow_process_activity AS WPA 
       ON WFP.id = WPA.source_id 
      INNER JOIN innovator.activity AS A 
       ON WPA.related_id = A.id 
) 
SELECT [CR Number] = [CRNumber], 
     Title, 
     [Date CR Created] = CONVERT(VARCHAR(10), DateCRCreated, 120), 
     [Activity Activated] = CONVERT(VARCHAR(10), ActivityActivated, 120), 
     [Activity Closed] = CONVERT(VARCHAR(10), ActivityClosed, 120), 
     [STATE], 
     [Activity Name] = ActivityName, 
     [DAYS ACTIVITY (WAS) OPEN] = [DAYSACTIVITYOPEN], 
     [DAYS ACTIVITY HAS BEEN OPEN] = [DAYSACTIVITYHASBEENOPEN] 
FROM CTE 
ORDER BY DateOfActiveActivity ASC, ActivityActivated, ActivityClosed; 

Demo with sample data on SQL Fiddle

+0

非常感謝,這個作品也很棒。 – Spacko 2013-03-11 10:22:24