mysql动态列转行怎么实现

avatar
作者
筋斗云
阅读量:2

在MySQL中,可以使用UNION操作符将动态列转换为行。下面是一个示例:

假设有一个名为“table”的表,其中包含以下列:id, name, col1, col2, col3。 要将col1、col2和col3转换为行,可以执行以下查询:

SELECT id, name, 'col1' AS column_name, col1 AS value FROM table UNION ALL SELECT id, name, 'col2' AS column_name, col2 AS value FROM table UNION ALL SELECT id, name, 'col3' AS column_name, col3 AS value FROM table 

这将返回一个结果集,其中每行包含id、name、column_name和value列。其中,column_name列将包含原始表中列的名称,value列将包含对应列的值。

注意:使用UNION ALL操作符可以保留重复行,如果想要去除重复行,可以使用UNION操作符替代UNION ALL。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!