首頁 > 資料庫 > mysql教程 > 如何使用聚合函數和 CASE 語句動態透視 MySQL 中的資料?

如何使用聚合函數和 CASE 語句動態透視 MySQL 中的資料?

Mary-Kate Olsen
發布: 2025-01-06 07:56:43
原創
596 人瀏覽過

How to Dynamically Pivot Data in MySQL Using Aggregate Functions and CASE Statements?

使用 MySQL 的聚合函數和 CASE 語句動態地轉換數據

考慮具有以下架構的產品部件表:

CREATE TABLE Parts (
    part_id INT NOT NULL,
    part_type CHAR(1) NOT NULL,
    product_id INT NOT NULL,
    PRIMARY KEY (part_id)
);
登入後複製

範例資料:

INSERT INTO Parts (part_id, part_type, product_id) VALUES
(1, 'A', 1),
(2, 'B', 1),
(3, 'A', 2),
(4, 'B', 2),
(5, 'A', 3),
(6, 'B', 3);
登入後複製

目標是將這些資料轉換為將產品零件表示為列的表:

CREATE TABLE PivotedParts (
    product_id INT NOT NULL,
    part_A_id INT,
    part_B_id INT,
    PRIMARY KEY (product_id)
);
登入後複製

動態透視解決方案:

MySQL沒有內建的PIVOT函數,但可以使用聚合函數和a來實現動態解決方案CASE語句:

SET @sql = NULL;
SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'max(case when part_type = ''',
      part_type,
      ''' then part_id end) AS part_',
      part_type, '_id'
    )
  ) INTO @sql
FROM
  Parts;

SET @sql = CONCAT('SELECT product_id, ', @sql, ' 
                  FROM Parts 
                   GROUP BY product_id');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
登入後複製

範例輸出:

+------------+----------+----------+
| product_id | part_A_id | part_B_id |
+------------+----------+----------+
| 1          | 1        | 2        |
| 2          | 3        | 4        |
| 3          | 5        | 6        |
+------------+----------+----------+
登入後複製
登入後複製

靜態旋轉解(對於有限數量的欄位):

對於列數有限的靜態透視解,可以使用以下查詢使用:

SELECT product_id,
  max(case when part_type ='A' then part_id end) as part_A_id,
  max(case when part_type ='B' then part_id end) as part_B_id
FROM Parts
GROUP BY product_id;
登入後複製

輸出:

+------------+----------+----------+
| product_id | part_A_id | part_B_id |
+------------+----------+----------+
| 1          | 1        | 2        |
| 2          | 3        | 4        |
| 3          | 5        | 6        |
+------------+----------+----------+
登入後複製
登入後複製

以上是如何使用聚合函數和 CASE 語句動態透視 MySQL 中的資料?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板