使用预准备语句在 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中文网其他相关文章!