2015-12-22 78 views
0

我想按月計算預算事務處理行的總和。如果我的查詢出現錯誤。 我查詢的結果是:獲取總和BudgetTransactionLine

RECIDLine RecIDHeader Date      Amount 
5637157326 5637149076 2012-08-01 00:00:00.000 850.00 
5637157342 5637149079 2012-12-01 00:00:00.000 1000.00 
5637157343 5637149079 2012-12-01 00:00:00.000 80.00 
5637157344 5637149079 2012-12-01 00:00:00.000 2700.00 

但我希望得到的財產以後這樣的:

RECIDLine RecIDHeader Date      Amount 
    5637157326 5637149076 2012-08-01 00:00:00.000 850.00 
    5637157342 5637149079 2012-12-01 00:00:00.000 3780.00 

這是我的查詢:

IF OBJECT_ID('tempdb..#BudgetTransTmp') IS NOT NULL 
     DROP TABLE #BudgetTransTmp 
    Select 
      BudgetTransactionLine.RECID          AS RecIdLine, 
      BUDGETTRANSACTIONHEADER.RECID         AS RecIdHeader, 
      BudgetTransactionLine.DATE, 
      SUM(CAST((BudgetTransactionLine.TransactionCurrencyAmount) as decimal(18,2))) AS Amount 
    INTO #BudgetTransTmp 
    FROM MicrosoftDynamicsAX.dbo.BudgetTransactionLine     AS BudgetTransactionLine 

      INNER JOIN MicrosoftDynamicsAX.dbo.BUDGETTRANSACTIONHEADER  AS BUDGETTRANSACTIONHEADER 
      ON BUDGETTRANSACTIONHEADER.RECID        = BudgetTransactionLine.BUDGETTRANSACTIONHEADER 
      AND BUDGETTRANSACTIONHEADER.budgetTransactionType    = '3' 
      AND BUDGETTRANSACTIONHEADER.PARTITION       = @Partition 

    WHERE BudgetTransactionLine.PARTITION         [email protected] 
      AND BudgetTransactionCode.DATAAREAID = 'USMF' 
      AND BudgetTransactionLine.DATE >= PeriodCalandarTmp.StartDate 
      AND BudgetTransactionLine.DATE <= PeriodCalandarTmp.EndDate 


    GROUP BY BudgetTransactionLine.DATE, 
       BUDGETTRANSACTIONHEADER.RECID, 
       BudgetTransactionLine.RECID    
    select * from #BudgetTransTmp 

,我需要保持BudgetTransactionLine。 RECID in select

回答

1

您不應該包含BudgetTransactionLine.RecIdRecIdLine)在您的GROUP BY

如果需要此列,則必須使用的Aggregate Function一個(例如在選擇部分MIN(BudgetTransactionLine.RecId) AS RecIdLine

0

只是把你在簡單的CTE整個數據,只是與你的臨時表連接,請去通過查詢根據該

下面的示例數據小心地插入你的代碼

declare @Table1 TABLE 
    (RECIDLine BIGint, RecIDHeader BIGint, Date varchar(30), Amount DECIMAL(18,2)) 
; 

INSERT INTO @Table1 
    (RECIDLine, RecIDHeader, Date, Amount) 
VALUES 
    (5637157326, 5637149076, '2012-08-01 00:00:00.000', 850.00), 
    (5637157342, 5637149079, '2012-12-01 00:00:00.000', 1000.00), 
    (5637157343, 5637149079, '2012-12-01 00:00:00.000', 80.00), 
    (5637157344, 5637149079, '2012-12-01 00:00:00.000', 2700.00) 
; 


;WITH CTE AS (
select RecIDHeader,Date,SUM(Amount)Amount,ROW_NUMBER()OVER(PARTITION BY RecIDHeader ORDER BY Date)RN from @Table1 
GROUP BY RecIDHeader,Date) 

Select T.RECIDLine,C.RecIDHeader,C.Amount,C.Amount FROM CTE C 
INNER JOIN (select MIN(RECIDLine) RECIDLine, RecIDHeader from @Table1 
GROUP BY RecIDHeader)T 
ON T.RecIDHeader = C.RecIDHeader