阅读量: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。