Mysql
 sql >> база данни >  >> RDS >> Mysql

MySql Транспониране на ред в колона и колона в ред

Можете да го направите по този начин

SELECT month,
       MAX(CASE WHEN unit = 'CS-1' THEN value END) `CS-1`,
       MAX(CASE WHEN unit = 'CS-2' THEN value END) `CS-2`,
       MAX(CASE WHEN unit = 'CS-3' THEN value END) `CS-3`
  FROM
(
  SELECT unit, month,
         CASE month 
            WHEN 'JAN' THEN jan
            WHEN 'FEB' THEN feb
            WHEN 'MAR' THEN mar
            WHEN 'APR' THEN apr
            WHEN 'MAY' THEN may
            WHEN 'JUN' THEN jun
         END value
    FROM table1 t CROSS JOIN
  (
    SELECT 'JAN' month UNION ALL
    SELECT 'FEB' UNION ALL
    SELECT 'MAR' UNION ALL
    SELECT 'APR' UNION ALL
    SELECT 'MAY' UNION ALL
    SELECT 'JUN'
  ) c
) q
 GROUP BY month
 ORDER BY FIELD(month, 'JAN', 'FEB', 'MAR', 'APR', 'MAY', 'JUN')
 

Изход:

<пред>| МЕСЕЦ | CS-1 | CS-2 | CS-3 ||-------|------|------|------|| ЯН | 100 | 111 | 331 || ФЕВ | 200 | 222 | 123 || MAR | 300 | 333 | 423 || ГПР | 400 | 444 | 923 || МАЙ | 500 | 555 | 918 || ЮНИ | 600 | 666 | 123 |

Ето SQLPiddle демонстрация




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Как да получа последния вмъкнат идентификатор на MySQL таблица в PHP?

  2. Разгръщане и управление на MySQL NDB клъстер с ClusterControl

  3. предоставя отдалечен достъп до базата данни MySQL от всеки IP адрес

  4. MySQL как да попълним липсващи дати в диапазона?

  5. Не мога да намеря my.cnf на моя компютър с Windows