qq_34011768 2022-04-09 10:46 采纳率: 82.4%
浏览 149
已结题

字段逗号分割 查询出来的sql是多列如何实现

数据库是这样的:

img


查询结果想要这样的:

img


不想用程序去控制,因为不确定这个分割字段的长度,产生的列数也不同,所以想用sql控制,sql也是动态的,而且后续查询要分页展示,列数也不确定暂时没有想到什么办法,看各位有什么好的办法,谢谢

  • 写回答

3条回答 默认 最新

  • ダ雨夹雪リ 2022-04-09 11:31
    关注
    
    create table t 
    (
        id int ,
        con VARCHAR(100)
    );
    
    
    insert into T values(1,'1,2,3,4,5,6');
    insert into T values(2,'9,8');
    
     
    set @sql='select id,';
    set @sql=CONCAT(@sql,(select GROUP_CONCAT('max(if(help_topic_id=',help_topic_id,',V,null)) as 字段',help_topic_id+1) from  mysql.help_topic where help_topic_id <(
    select max(LENGTH(con)-LENGTH(replace(con,',',''))) from t )));
    set @sql=CONCAT(@sql,'
    from 
    ( 
     SELECT t.id,help_topic_id,substring_index(substring_index(con,'','', help_topic_id + 1), '','', -1)  as v
     FROM   mysql.help_topic,T
     where help_topic_id < (LENGTH(con) - LENGTH(REPLACE(con, '','', '''')) + 1)
    ) a
    group by id ');
     
     
    PREPARE stmt FROM @sql;       
    EXECUTE stmt ;        
    deallocate prepare stmt;      
    
    
     
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月17日
  • 已采纳回答 4月9日
  • 创建了问题 4月9日

悬赏问题

  • ¥15 求指导ADS低噪放设计
  • ¥15 CARSIM前车变道设置
  • ¥50 三种调度算法报错 有实例
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存