簡體   English   中英

SQL將行合並為單行

[英]SQL Combine Rows into Single Row

仍然在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

簡單回答:從GROUP BY子句中刪除MONTH(expdate) ,並移動每個SUM以包含其CASE子句 - 如下所示:

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功能。)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM