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

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日

悬赏问题

  • ¥15 mmocr的训练错误,结果全为0
  • ¥15 python的qt5界面
  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀