Reformat Department Table

Write an SQL query to reformat the table such that there are a department id column and a revenue column for each month.

Example:


Table: Department:
+------+---------+-------+
| id   | revenue | month |
+------+---------+-------+
1    | 8000    | Jan   |
2    | 9000    | Jan   |
3    | 10000   | Feb   |
1    | 7000    | Feb   |
1    | 6000    | Mar   |
+------+---------+-------+

Result:
+------+-------------+-------------+-------------+-------------+
| id   | Jan_Revenue | Feb_Revenue | Mar_Revenue | Dec_Revenue |
+------+-------------+-------------+-------------+-------------+
1    | 8000        | 7000        | 6000        | null        |
2    | 9000        | null        | null        | null        |
3    | null        | 10000       | null        | null        |
+------+-------------+-------------+-------------+-----+-------+

Approach

Mysql

SELECT id ,
    SUM(CASE WHEN month = 'Jan' THEN revenue END)  AS Jan_Revenue,
    SUM(CASE WHEN month = 'Feb' THEN revenue ENDAS Feb_Revenue,
    SUM(CASE WHEN month = 'Mar' THEN revenue ENDAS Mar_Revenue,
    SUM(CASE WHEN month = 'Apr' THEN revenue ENDAS Apr_Revenue,
    SUM(CASE WHEN month = 'May' THEN revenue ENDAS May_Revenue,
    SUM(CASE WHEN month = 'Jun' THEN revenue ENDAS Jun_Revenue,
    SUM(CASE WHEN month = 'Jul' THEN revenue ENDAS Jul_Revenue,
    SUM(CASE WHEN month = 'Aug' THEN revenue ENDAS Aug_Revenue,
    SUM(CASE WHEN month = 'Sep' THEN revenue ENDAS Sep_Revenue,
    SUM(CASE WHEN month = 'Oct' THEN revenue ENDAS Oct_Revenue,
    SUM(CASE WHEN month = 'Nov' THEN revenue ENDAS Nov_Revenue,
    SUM(CASE WHEN month = 'Dec' THEN revenue ENDAS Dec_Revenue
FROM department GROUP BY id ORDER BY id;

Oracle

SELECT id ,
    SUM(CASE WHEN month = 'Jan' THEN revenue END)  AS Jan_Revenue,
    SUM(CASE WHEN month = 'Feb' THEN revenue ENDAS Feb_Revenue,
    SUM(CASE WHEN month = 'Mar' THEN revenue ENDAS Mar_Revenue,
    SUM(CASE WHEN month = 'Apr' THEN revenue ENDAS Apr_Revenue,
    SUM(CASE WHEN month = 'May' THEN revenue ENDAS May_Revenue,
    SUM(CASE WHEN month = 'Jun' THEN revenue ENDAS Jun_Revenue,
    SUM(CASE WHEN month = 'Jul' THEN revenue ENDAS Jul_Revenue,
    SUM(CASE WHEN month = 'Aug' THEN revenue ENDAS Aug_Revenue,
    SUM(CASE WHEN month = 'Sep' THEN revenue ENDAS Sep_Revenue,
    SUM(CASE WHEN month = 'Oct' THEN revenue ENDAS Oct_Revenue,
    SUM(CASE WHEN month = 'Nov' THEN revenue ENDAS Nov_Revenue,
    SUM(CASE WHEN month = 'Dec' THEN revenue ENDAS Dec_Revenue
FROM department GROUP BY id ORDER BY id;


No comments:

Post a Comment