餘發 2024-01-05 14:12 采纳率: 0%
浏览 17

MySql行转列问题

Mysql行转列问题

表原始数据:

img

查询修改结果为:

img

其中b列中的值不止上述几种,还有很多,但是无法实际列举,如何才能在不知其列内容的情况下实现行转列。

  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2024-01-05 16:20
    关注

    【以下回答由 GPT 生成】

    这个问题可以通过使用动态SQL语句来解决。以下是一个可能的解决方案:

    1. 首先,我们需要查询原始表中所有不同的name值,以便动态生成新表的列名。可以使用以下SQL语句来获取不同的name值:
    SELECT DISTINCT name FROM 原始表;
    
    1. 将上述查询结果作为子查询,并使用GROUP_CONCAT函数来动态生成SQL语句中的列名部分。可以使用以下SQL语句来生成列名部分:
    SELECT GROUP_CONCAT(DISTINCT CONCAT('MAX(IF(name = ''', name, ''', value, NULL)) AS ', name)) INTO @sql FROM (SELECT DISTINCT name FROM 原始表) AS subquery;
    

    这个查询将生成一条包含MAX和IF函数的SQL语句,并将其保存到@sql变量中。这条SQL语句将按照不同的name值生成对应的列名。

    1. 使用上述生成的SQL语句来动态生成新表的结构。可以使用以下SQL语句来创建转换后的表:
    SET @sql = CONCAT('CREATE TABLE 转换后的表 AS SELECT id, name, ', @sql, ' FROM 原始表 GROUP BY id;');
    PREPARE stmt FROM @sql;
    EXECUTE stmt;
    

    这条SQL语句将动态生成一个CREATE TABLE语句,并将转换后的表作为结果保存到新表中。

    1. 最后,我们可以查询转换后的表来验证结果。可以使用以下SQL语句来查询转换后的表:
    SELECT * FROM 转换后的表;
    

    这个查询将返回转换后的表,其中列A和列B是根据原始表中的name列动态生成的。

    注意:由于这个解决方案使用了动态SQL和临时表,可能需要适应具体的环境和数据情况进行调整。

    如果你需要更加具体的代码实现,请提供你使用的编程语言和MySQL连接方式,我可以帮助你进一步实现。



    【相关推荐】



    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    评论

报告相同问题?

问题事件

  • 创建了问题 1月5日