まだ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