mysql把一字段根据分隔符拆分为多行依次展示

注:要是有哪个函数看不懂依次的查,慢慢就看懂了,不要先进行复杂的操纵,自己建个简单的测试一下,成功之后你自己就有自己的感觉了,要不然直接复制粘贴一脸懵逼。
在这里插入图片描述上面的图片是目标拆分的代码,根据‘/’来进行拆分得到多行数据。效果如下
在这里插入图片描述
话不多说,上代码:

SELECT
  t.targetColumn,
  substring_index(
    substring_index(t.sourceColumn,'/',b.help_topic_id + 1),'/' ,- 1
  )
FROM
  syjxdata t
JOIN mysql.help_topic b 
ON b.help_topic_id < (
  length(t.sourceColumn) - length(REPLACE (t.sourceColumn, '/', '')) + 1)



WHERE
  1 = 1
AND t.sourcetable IS NOT NULL
AND t.sourcesystem IS NOT NULL
and t.sourceColumn is not null and t.sourceColumn <> ''
ORDER BY t.targetColumn

里面的代码看似有很多函数,实际上主体上是由mysql本身自带的mysql.help_topic这个函数库为基础上的改进,大致的意思是通过分割字符串后遍历依次得到分割后的数据。

substring_index(
    substring_index(t.sourceColumn,'/',b.help_topic_id + 1),'/' ,- 1
  )  

substring_index函数是包含,意思是取b.help_topic_id + 1前面的所有数,最外层套一层是只取最后的数据。即使每次索引增加把前面所有的数据都包含,但是只取最新加入的一条数据。

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值