sql >> Databasteknik >  >> RDS >> Mysql

MySQL Pivot Table Head Scratcher

Som redan nämnts är MySQL inte byggd för att pivotera på egen hand och du bör förmodligen pivotera i kod om möjligt, men förutom det, nedan är några exempel på SQL som ska göra vad du vill. Förutsatt att din faktiska tabell är variabel i någon mening (som hur många q[x]-kolumner du har, eller hur många super_id:s du har), kan du slå ihop detta i en lagrad procedur för att dynamiskt generera och exekvera nödvändig SQL.

Om vi ​​antar en initial tabell med namnet testTable:

mysql> select * from testTable;
+----------+--------+------+------+
| super_id | cat_id | qa   | qb   |
+----------+--------+------+------+
|        1 |      1 |    5 |    5 | 
|        1 |      2 |    2 |    5 | 
|        1 |      3 |    3 |    4 | 
|        2 |      4 |    5 |    3 | 
|        2 |      5 |    3 |    4 | 
|        2 |      6 |    4 |    2 | 
+----------+--------+------+------+
6 rows in set (0.00 sec)

Använd följande SQL:

SELECT
    'qa' q,
    SUM( CASE WHEN super_id = 1 THEN qa ELSE 0 END )/SUM( CASE WHEN super_id = 1 THEN 1 ELSE 0 END ) super_id_1,
    SUM( CASE WHEN super_id = 2 THEN qa ELSE 0 END )/SUM( CASE WHEN super_id = 2 THEN 1 ELSE 0 END ) super_id_2
FROM
    testTable
UNION ALL
SELECT
    'qb' q,
    SUM( CASE WHEN super_id = 1 THEN qb ELSE 0 END )/SUM( CASE WHEN super_id = 1 THEN 1 ELSE 0 END ) super_id_1,
    SUM( CASE WHEN super_id = 2 THEN qb ELSE 0 END )/SUM( CASE WHEN super_id = 2 THEN 1 ELSE 0 END ) super_id_2
FROM
    testTable
;

För att uppnå detta resultat:

+----+------------+------------+
| q  | super_id_1 | super_id_2 |
+----+------------+------------+
| qa |     3.3333 |     4.0000 | 
| qb |     4.6667 |     3.0000 | 
+----+------------+------------+
2 rows in set (0.00 sec)

(redigera:formatering)




  1. postgresql-sekvens nextval i schema

  2. Mycket ihållande /opt/lampp/bin/mysql.server:264:kill:Ingen sådan process. Xampp/ubuntu 16.04

  3. fel när du använder mysql_real_escape_string()

  4. mysql VÄLJ det bästa av varje kategori i en enda tabell