1

まだSQLで歯を削っています。これが現在の私のクエリです(後ですべての月を含めるように拡張します):

SELECT catid, 
CASE WHEN MONTH(expdate) = '1' then SUM(expamount) END AS 'january', 
CASE WHEN MONTH(expdate) = '2' then SUM(expamount) END AS 'february', 
CASE WHEN MONTH(expdate) = '4' then SUM(expamount) END AS 'april' 
FROM users LEFT JOIN (expcategories INNER JOIN expenses ON  catid = catid_fk) 
ON userid=userid_fk WHERE userid='1' GROUP BY catid, MONTH(expdate)

現在の結果

catid     January     February     April
1         123.0000    NULL         NULL
2         NULL        500.000      NULL
1         NULL        NULL         505.0000

次のように、特定の結果がcatid単一の行に返されるようにします。

望ましい結果

catid     January     February     April
1         123.0000    NULL         505.0000
2         NULL        500.000      NULL
4

1 に答える 1

3

簡単な答え: 節から削除MONTH(expdate)し、それぞれをその節を囲むようGROUP BYに移動します- 次のように:SUMCASE

SELECT catid, 
       SUM(CASE WHEN MONTH(expdate) = '1' then expamount END) AS 'january', 
       SUM(CASE WHEN MONTH(expdate) = '2' then expamount END) AS 'february', 
       SUM(CASE WHEN MONTH(expdate) = '4' then expamount END) AS 'april' 
FROM users 
LEFT JOIN (expcategories INNER JOIN expenses ON  catid = catid_fk) 
ON userid=userid_fk WHERE userid='1' 
GROUP BY catid

(または、SQLServer のPIVOT機能を使用することを検討してください。)

于 2013-04-28T17:45:01.553 に答える