MySQL分割字符串一行转多行的实现方法

 更新时间:2023年06月13日 14:44:35   作者:midasism  
这篇文章主要介绍了MySQL分割字符串一行转多行,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

需求

MySQL中,某个字段通过分隔符保存了多个字符串,如下:

需要将字段中的字符串分成不同的行,如下:

用到的知识

MySQL提供了一系列字符串处理函数
1、left(str, len):从左边开始截取指定长度
2、right(str, len):从右边开始截取指定长度
3、substring(str, pos):从第pos个字符开始截取(注意从1开始计数)

  • 当pos为正数:从左往右数第pos个
  • 当pos为负数:从右往左数第pos个

比如pos为-2,字符串为"a,b,c",截取结果为",c"

4、substring(str, pos, len):从第pos个字符开始截取指定长度(注意从1开始计数)
5、substring_index(str, delim, count):根据delim分隔符进行分割,从头开始截取到第count个分隔符之前
select id, substring_index("a,b,c", ',', 2) from test_split;
截取到第二个分隔符之前

最终实现

实现效果

select 
	b.help_topic_id + 1 as id, 
	substring_index(substring_index(a.name, ',', b.help_topic_id + 1) ,',', -1) as name
from
	test_split a join mysql.help_topic b 
	on 
	b.help_topic_id < LENGTH(a.name) - LENGTH(REPLACE(a.name,',','')) + 1;

一行变成多行,需要借助辅助表,这里选择mysql.help_topic
mysql.help_topic表的id特点是从0开始递增,最大为700

1、分割成多少份:LENGTH(a.name) - LENGTH(REPLACE(a.name, ',' , '')) + 1

  • length(‘a,b,c’) - length( replace(‘a,b,c’, ‘,’, ‘’) ) + 1 = 5 - 3 + 1 = 3
  • 原始长度 - 去掉分隔符,之后的长度 = 分隔符数量
  • 分隔符数量 + 1 = 被分割的数量

2、获取分割之后的每一份字符串
2.1、substring_index(a.name, ',', b.help_topic_id + 1):随着help_topic_id增加,截取的字符串依次增加,“a”、“a,b”、“a,b,c”……
2.2、substring_index(str, ',' , -1):获取str按分隔符分割之后的最后一个字符串
substring_index(substring_index(a.name, ',', b.help_topic_id + 1) , ',', -1)由2.1可知,随着help_topic_id增加,依次获取"a" “b” “c”……

参考链接

https://www.jb51.net/article/248795.htm

到此这篇关于MySQL分割字符串一行转多行的文章就介绍到这了,更多相关MySQL分割字符串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL group by对单字分组序和多字段分组的方法讲解

    MySQL group by对单字分组序和多字段分组的方法讲解

    今天小编就为大家分享一篇关于MySQL group by对单字分组序和多字段分组的方法讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • mysql zip 文件安装教程

    mysql zip 文件安装教程

    这篇文章主要为大家详细介绍了mysql zip 文件安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-04-04
  • MySQL中的IF语句使用小结

    MySQL中的IF语句使用小结

    在MySQL数据库中,IF 语句是一种常见的条件控制语句,本文介绍了 MySQL 中 IF 语句的基本用法以及实际应用场景,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • MySQL 语句注释方式简介

    MySQL 语句注释方式简介

    这篇文章主要介绍了MySQL 语句注释方式简介,方法非常简单,需要的朋友可以了解下。
    2017-10-10
  • SQL索引失效的11种情况详析

    SQL索引失效的11种情况详析

    索引并不是时时都会生效的,遇到一些情况将导致索引失效,下面这篇文章主要给大家介绍了关于SQL索引失效的11种情况,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • MySQL 5.0.16乱码问题的解决方法

    MySQL 5.0.16乱码问题的解决方法

    这篇文章主要介绍了MySQL 5.0.16乱码问题的解决方法,需要的朋友可以参考下
    2015-10-10
  • MySQL日期函数与日期转换格式化函数大全

    MySQL日期函数与日期转换格式化函数大全

    Mysql作为一款开元的免费关系型数据库,用户基础非常庞大,本文列出了MYSQL常用日期函数与日期转换格式化函数
    2018-03-03
  • MYSQL根据分组获取组内多条数据中符合条件的一条(实例详解)

    MYSQL根据分组获取组内多条数据中符合条件的一条(实例详解)

    这篇文章主要介绍了MYSQL根据分组获取组内多条数据中符合条件的一条,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • MySQL数据类型之浅谈字符串(string)

    MySQL数据类型之浅谈字符串(string)

    这篇文章主要介绍了MySQL数据类型之字符串(string)的使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • homeassistant数据存储到mysql数据库方式

    homeassistant数据存储到mysql数据库方式

    这篇文章主要介绍了homeassistant数据存储到mysql数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12

最新评论