簡體   English   中英

MySQL中的數據透視表 - 使用varchar格式的值轉換為數據透視表

[英]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演示

為轉換編寫存儲過程。

  1. SELECT DISTINCT name FROM table1; 獲取Pivot_table的列列表。 為主題創建具有適當列數+ 1的表。

  2. 在數據透視表中插入所有主題,為每個主題獲得1行。 INSERT ... from SELECT DISTINCT subject FROM table1

  3. 創建游標以從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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM