首页 > 数据库 > 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
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板