温馨提示×

mysql动态列转行怎么实现

小亿
216
2023-12-14 09:40:15
栏目: 云计算

在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。

0