Linux 拨号vps windows公众号手机端

mysql动态列转行怎么实现

lewis 9年前 (2016-11-14) 阅读数 11 #VPS/云服务器
文章标签 mysql

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

版权声明

本文仅代表作者观点,不代表米安网络立场。

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

热门