[英]Pivot table in MySQL - convert to pivot table with values in varchar format
我希望轉換Table1中的數據,如Pivot_table中數據的第一張圖片所示。 有可能在MySQL中這樣做嗎? 因為數據透視表(A,B,C,D)的值是varchar數據格式,我不能像SUM那樣使用MySQL的任何聚合函數。
Table1:
PK Name Subject Grade
-------------------------------------
1 Bob Math A
2 Bob History B
3 Bob Language C
4 Bob Biology D
5 Sue History C
6 Sue Math A
7 Sue Music A
8 Sue Geography C
Pivot_table:
Subject Bob Sue
-------------------------
Math A A
History B C
Language C
Biology D
Music A
Geography C
謝謝你的幫助
靜態查詢(僅涉及Bob和Sue)可能如下所示
SELECT subject,
MAX(CASE WHEN name = 'Bob' THEN grade END) `Bob`,
MAX(CASE WHEN name = 'Sue' THEN grade END) `Sue`
FROM table1
GROUP BY subject
現在能夠考慮其他名稱使用像這樣的動態SQL
SET @sql = NULL;
SELECT GROUP_CONCAT(DISTINCT
CONCAT('MAX(CASE WHEN name = ''', name,
''' THEN grade END) `', name, '`'))
INTO @sql
FROM table1;
SET @sql = CONCAT('SELECT subject, ', @sql, '
FROM table1
GROUP BY subject');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
輸出:
| SUBJECT | BOB | SUE | |-----------|--------|--------| | Biology | D | (null) | | Geography | (null) | C | | History | B | C | | Language | C | (null) | | Math | A | A | | Music | (null) | A |
這是SQLFiddle演示
您可以將其包裝到存儲過程中以簡化調用端的操作
DELIMITER $$
CREATE PROCEDURE sp_grade_report()
BEGIN
SET @sql = NULL;
SELECT GROUP_CONCAT(DISTINCT
CONCAT('MAX(CASE WHEN name = ''', name,
''' THEN grade END) `', name, '`'))
INTO @sql
FROM table1;
SET @sql = CONCAT('SELECT subject, ', @sql, '
FROM table1
GROUP BY subject');
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END$$
DELIMITER ;
樣品用法:
CALL sp_grade_report();
這是SQLFiddle演示
為轉換編寫存儲過程。
SELECT DISTINCT name FROM table1;
獲取Pivot_table的列列表。 為主題創建具有適當列數+ 1的表。
在數據透視表中插入所有主題,為每個主題獲得1行。 INSERT ... from SELECT DISTINCT subject FROM table1
。
創建游標以從table1中檢索所有記錄。 遍歷游標的所有行,並為每一行調用UPDATE Pivot_table SET [COLUMN_NAME for studetn value]=[grade value] WHERE subject=[subject name value];
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.