2013-08-02 74 views
0

這裏的查詢......如何獲得最後的運行餘額?

+------+----------------+----+----+------------+-----+--------+------+ 
| seq | idClient  | i | WN | fld_Date | PSF | BAL | TBAL | 
+------+----------------+----+----+------------+-----+--------+------+ 
| 1483 | SUB-01-1304002 | 1 | 11 | 2013-03-12 | 50 | 50.00 | 0.00 | 
| 1486 | SUB-01-1304002 | 2 | 12 | 2013-03-19 | 25 | 75.00 | 0.00 | 
| 1489 | SUB-01-1304002 | 3 | 13 | 2013-03-26 | 20 | 95.00 | 0.00 | 
| 1492 | SUB-01-1304002 | 4 | 14 | 2013-04-02 | 20 | 115.00 | 0.00 | 
| 1495 | SUB-01-1304002 | 5 | 15 | 2013-04-09 | 20 | 135.00 | 0.00 | 
| 1498 | SUB-01-1304002 | 6 | 16 | 2013-04-16 | 20 | 155.00 | 0.00 | 
| 1501 | SUB-01-1304002 | 7 | 17 | 2013-04-23 | 20 | 175.00 | 0.00 | 
| 1504 | SUB-01-1304002 | 8 | 18 | 2013-04-30 | 20 | 195.00 | 0.00 | 
| 1507 | SUB-01-1304002 | 9 | 19 | 2013-05-07 | 20 | 215.00 | 0.00 | 
| 1510 | SUB-01-1304002 | 10 | 20 | 2013-05-14 | 20 | 235.00 | 0.00 | 
| 1513 | SUB-01-1304002 | 11 | 21 | 2013-05-21 | 20 | 255.00 | 0.00 | 
| 1516 | SUB-01-1304002 | 12 | 22 | 2013-05-28 | 20 | 275.00 | 0.00 | 
| 1519 | SUB-01-1304002 | 13 | 23 | 2013-06-04 | 20 | 295.00 | 0.00 | 
| 1522 | SUB-01-1304002 | 14 | 24 | 2013-06-11 | 20 | 315.00 | 0.00 | 
| 1525 | SUB-01-1304002 | 15 | 25 | 2013-06-18 | -30 | 285.00 | 0.00 | 
| 1548 | SUB-01-1304002 | 16 | 26 | 2013-06-25 | 20 | 305.00 | 0.00 | 
+------+----------------+----+----+------------+-----+--------+------+ 

這是我想表現

+------+----------------+----+----+------------+-----+--------+------+ 
| seq | idClient  | i | WN | fld_Date | PSF | BAL | TBAL | 
+------+----------------+----+----+------------+-----+--------+------+ 
| 1548 | SUB-01-1304002 | 16 | 26 | 2013-06-25 | 20 | 305.00 | 0.00 | 
+------+----------------+----+----+------------+-----+--------+------+ 

我已經使用最大輸出,但沒有奏效。任何人都可以幫助我。

這裏是我的代碼

SELECT 
MAX(seq) seq, 
idClient, 
BAL 
FROM 
(
SELECT 
seq, 
idClient, 
IF (
@idClient = (@idClient := idClient), 
@id :[email protected] + 1, 
@id := 1 
) i, 
WEEKOFYEAR(fld_Date) WN, 
fld_Date, 
PSF, 
IF(@id=1,@BAL:=PSF,@BAL:[email protected]+PSF) BAL, 
FORMAT(@TBAL := COALESCE(@BAL*@DD,0),2) AS TBAL 
FROM 
(
    SELECT 
     a.seq, 
     a.idClient, 
     a. fld_Date, 
     a.PSF 
    FROM 
     (
SELECT 
db_lms.lms_savings.seq, 
db_lms.lms_savings.idClient, 
db_lms.lms_savings.PSF, 
db_lms.lms_savings.fld_Date 
FROM 
db_lms.lms_savings 
WHERE db_lms.lms_savings.idClient = 'SUB-01-1304002' 
      ORDER BY 
       db_lms.lms_savings.idClient, 
       db_lms.lms_savings.fld_Date 
     ) a 
    GROUP BY 
     a.seq 
    ORDER BY 
     idClient, 
     fld_Date 
) a, 
(SELECT @id := 0, @idClient := '', @BAL := 0) B 
) z 
GROUP BY idClient 
+0

你想有一排MAX(SEQ)或最大(BAL)或最後以次? – iiro

+0

我需要在查詢中顯示最新的運行餘額,因爲餘額依賴於其他字段,因此無法使用max。我在seq中使用max,只是試圖顯示我認爲餘額將是305.00的最後一個記錄... – xdiver

回答

0

嘗試

SELECT z.* 
    FROM 
(
    SELECT seq, 
     idClient, 
     IF ( 
       @idClient = (@idClient := idClient), 
       @id :[email protected] + 1, 
       @id := 1 
     ) i, 
     WEEKOFYEAR(fld_Date) WN, 
     fld_Date, 
     PSF, 
     IF(@id=1, @BAL:=PSF, @BAL := @BAL + PSF) BAL, 
     FORMAT(@TBAL := COALESCE(@BAL * @DD, 0), 2) AS TBAL 
    FROM 
    (
     SELECT a.seq, 
      a.idClient, 
      a. fld_Date, 
      a.PSF 
     FROM 
     (
     SELECT db_lms.lms_savings.seq, 
       db_lms.lms_savings.idClient, 
       db_lms.lms_savings.PSF, 
       db_lms.lms_savings.fld_Date 
      FROM db_lms.lms_savings 
     WHERE db_lms.lms_savings.idClient = 'SUB-01-1304002' 
     ORDER BY db_lms.lms_savings.idClient, 
       db_lms.lms_savings.fld_Date 
    ) a 
     GROUP BY a.seq 
     ORDER BY idClient, 
       fld_Date 
) a, 
    (SELECT @id := 0, @idClient := '', @BAL := 0) b 
) z 
ORDER BY seq DESC 
LIMIT 1; 
+0

是的,我明白了。謝謝petern。順便說一下,如果我添加另一個idClient(SUB-01-1304003和SUB-01-1304004)並且它們也具有相同的功能,如何獲得它們的最近/最近的運行平衡? – xdiver

+0

@xenonleaux你是非常歡迎:)。至於你的後續問題 - 在評論中回答足夠複雜。但實際上,您可以通過idClient,seq DESC命令引入一個新變量並按組(每個idClient)枚舉行,然後僅選擇行號爲1的行。這將至少添加更多的外部選擇到您的查詢。 – peterm

0

這是你需要什麼?

SELECT 
    * 
FROM 
    lms_savings 
WHERE 
    seq = 
    (
     SELECT 
      seq 
     FROM 
      lms_savings 
     ORDER BY 
      fld_Date DESC 
     LIMIT 1 
    ) 
+0

是的,這是可能的,但我需要使用我上面的sql代碼來生成輸出.... – xdiver

+0

因此,應用這個查詢到你的查詢。 –

+0

如何?能給我看看麼? – xdiver