Wie bereits erwähnt, ist MySQL nicht dafür ausgelegt, sich selbst zu drehen, und Sie sollten wahrscheinlich im Code drehen, wenn dies möglich ist. Abgesehen davon finden Sie unten einige Beispiel-SQL, die das tun sollten, was Sie wollen. Angenommen, Ihre eigentliche Tabelle ist in gewissem Sinne variabel (z. B. wie viele q[x]-Spalten Sie haben oder wie viele super_ids Sie haben), können Sie dies in eine gespeicherte Prozedur einpacken, um das erforderliche SQL dynamisch zu generieren und auszuführen.
Angenommen, eine anfängliche Tabelle mit dem Namen 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)
Verwenden Sie die folgende 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
;
Um dieses Ergebnis zu erzielen:
+----+------------+------------+
| q | super_id_1 | super_id_2 |
+----+------------+------------+
| qa | 3.3333 | 4.0000 |
| qb | 4.6667 | 3.0000 |
+----+------------+------------+
2 rows in set (0.00 sec)
(Bearbeiten:Formatierung)