mysql列转行仅适用于复杂逻辑sql脚本
select substring_index(
substring_index(t1.ori_comma_values, ',', t2.split_times), ',', -1) as split_value
from (select '13055,28917,33583,42776,43832,' ori_comma_values) t1
inner join (
-- 无实际意义,用于兼容被转义列中实际数据的个数,这里认为列中有1000个有效数据 可以无限大,用于兜底
select (@i := @i + 1) as split_times from t_table01 t join (select @i := 0) n limit 1000
) t2
-- 原数据字符长度 - 去掉了分割字符的数据字符长度 = 得到实际有效数据个数
on char_length(t1.ori_comma_values) - char_length(replace (t1.ori_comma_values, ',', '')) >= t2.split_times - 1
本文作者:Journey&Flower
本文链接:https://www.cnblogs.com/JourneyOfFlower/p/18197860
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步