首頁 > 資料庫 > mysql教程 > 如何使用準備好的語句動態透視 MySQL 中的資料?

如何使用準備好的語句動態透視 MySQL 中的資料?

Mary-Kate Olsen
發布: 2025-01-06 07:36:40
原創
604 人瀏覽過

How to Dynamically Pivot Data in MySQL Using Prepared Statements?

使用預準備語句在MySQL 中進行動態透視

MySQL 缺乏原生PIVOT 函數,但您可以使用聚合函數和CASE 語句來模擬它。對於動態資料透視,準備好的語句提供了一個有效的解決方案。

考慮一個包含產品零件表的場景:

CREATE TABLE Parts (
    part_id INT,
    part_type VARCHAR(1),
    product_id INT
);
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);
登入後複製

所需的輸出是一個匯總了每個零件 ID的透視表產品:

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

動態旋轉查詢

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;
登入後複製

靜態透視查詢(有限列)

靜態透視查詢(有限列)

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;
登入後複製
靜態透視圖>對於具有固定數量透視列的靜態查詢:

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

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