mysql拆分字符串(MySQL 字符串拆分操作含分隔符的字符串截取)
mysql拆分字符串
MySQL 字符串拆分操作含分隔符的字符串截取无分隔符的字符串截取
题目要求
数据库中字段值:
实现效果:需要将一行数据变成多行
实现的sql
|
select left ( substring ( 'p1111' ,help_topic_id+1),1) as num from mysql.help_topic where help_topic_id < length( 'p1111' ); |
涉及的知识点
一、字符串截取:substring(str,pos)
1、参数说明
参数名 | 解释 |
---|---|
str | 需要拆分的字符串 |
delim | 分隔符,通过某字符进行拆分 |
count | 当 count 为正数,取第 n 个分隔符之前的所有字符; 当 count 为负数,取倒数第 n 个分隔符之后的所有字符。 |
2、 举例
(1)获取第2个以“,”逗号为分隔符之前的所有字符。
|
substring_index( '7654,7698,7782,7788' , ',' ,2) |
(2)获取倒数第2个以“,”逗号分隔符之后的所有字符
|
substring_index( '7654,7698,7782,7788' , ',' ,-2) |
二、替换函数:replace( str, from_str, to_str)
1、参数解说
参数名 | 解释 |
---|---|
str | 需要进行替换的字符串 |
from_str | 需要被替换的字符串 |
to_str | 需要替换的字符串 |
2、 举例
(1)将分隔符“,”逗号替换为“”空。
|
replace ( '7654,7698,7782,7788' , ',' , '' ) |
三、获取字符串长度:length( str )
1、参数解说
参数名 | 解释 |
---|---|
str | 需要计算长度的字符串 |
2、举例
(1)获取 ‘7654,7698,7782,7788' 字符串的长度
|
length( '7654,7698,7782,7788' ) |
实现的sql解析
|
select substring_index(substring_index( '7654,7698,7782,7788' , ',' ,help_topic_id+1), ',' ,-1) as num from mysql.help_topic where help_topic_id < length( '7654,7698,7782,7788' )-length( replace ( '7654,7698,7782,7788' , ',' , '' ))+1 |
此处利用 mysql 库的 help_topic 表的 help_topic_id 来作为变量,因为 help_topic_id 是自增的,当然也可以用其他表的自增字段辅助。
help_topic 表:
实现步骤:
step1:首先获取最后需被拆分成多少个字符串,利用 help_topic_id 来模拟遍历 第n个字符串。
涉及的代码片段:
|
help_topic_id < length( '7654,7698,7782,7788' )-length( replace ( '7654,7698,7782,7788' , ',' , '' ))+1 |
step2:根据“,”逗号来拆分字符串,此处利用 substring_index(str, delim, count) 函数,最后把结果赋值给 num 字段。
涉及的代码片段:
|
substring_index(substring_index( '7654,7698,7782,7788' , ',' ,help_topic_id+1), ',' ,-1) as num |
第一步:
以”,”逗号为分隔符,根据 help_topic_id 的值来截取第n+1个分隔符之前所有的字符串。 (此处 n+1 是因为help_topic_id 是从0开始算起,而此处需从第1个分隔符开始获取。)
|
substring_index( '7654,7698,7782,7788' , ',' ,help_topic_id+1) |
eg:
当 help_topic_id = 0时,获取到的字符串 = 7654
当 help_topic_id = 1时,获取到的字符串 = 7654,7698
…(以此类推)
第二步:
以”,”逗号为分隔符,截取倒数第1个分隔符之后的所有字符串。
|
substring_index(substring_index( '7654,7698,7782,7788' , ',' ,help_topic_id+1), ',' ,-1) |
eg:
根据第一步,当 help_topic_id = 0时,获取到的字符串 = 7654,此时第二步截取的字符串 = 7654
根据第一步,当 help_topic_id = 1时,获取到的字符串 = 7654,7698,此时第二步截取的字符串 = 7698
…(以此类推)
最终成功实现了以下效果 ~
注:不含分隔符的字符串拆分可参考 mysql——字符串拆分(无分隔符的字符串截取)
补充:mysql字段分隔符拆分_mysql里实现类似split的分割字符串的函数
下边的函数,实现了象数组一样去处理字符串。
一、用临时表作为数组
|
create function f_split(@c varchar (2000),@split varchar (2)) returns @t table (col varchar (20)) as begin while(charindex(@split,@c)<>0) begin insert @t(col) values ( substring (@c,1,charindex(@split,@c)-1)) set @c = stuff(@c,@c), '' ) end insert @t(col) values (@c) return end go select * from dbo.f_split( 'dfkd,dfdkdf,dfdkf,dffjk' , ',' ) drop function f_split col -------------------- dfkd dfdkdf dfdkf dffjk |
(所影响的行数为 4 行)
二、按指定符号分割字符串
返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果。
|
create function get_strarraylength ( @str varchar (1024), --要分割的字符串 @split varchar (10) --分隔符号 ) returns int as begin declare @location int declare @start int declare @length int set @str=ltrim(rtrim(@str)) set @location=charindex(@split,@str) set @length=1 while @location<>0 begin set @start=@location+1 set @location=charindex(@split,@str,@start) set @length=@length+1 end return @length end |
调用示例:
|
select dbo.get_strarraylength( '78,2,3' ,') |
返回值:4
三、按指定符号分割字符串
返回分割后指定索引的第几个元素,象数组一样方便
|
create function get_strarraystrofindex ( @str varchar (1024), --要分割的字符串 @split varchar (10), --分隔符号 @ index int --取第几个元素 ) returns varchar (1024) as begin declare @location int declare @start int declare @ next int declare @seed int set @str=ltrim(rtrim(@str)) set @start=1 set @ next =1 set @seed=len(@split) set @location=charindex(@split,@str) while @location<>0 and @ index >@ next begin set @start=@location+@seed set @location=charindex(@split,@start) set @ next =@ next +1 end if @location =0 select @location =len(@str)+1 --这儿存在两种情况:1、字符串不存在分隔符号 2、字符串中存在分隔符号,跳出while循环后,@location为0,那默认为字符串后边有一个分隔符号。 return substring (@str,@start,@location-@start) end |
调用示例:
|
select dbo.get_strarraystrofindex( '8,9,4' ,2) |
返回值:9
四、结合上边两个函数,象数组一样遍历字符串中的元素
|
declare @str varchar (50) set @str= '1,3,4,5' declare @ next int set @ next =1 while @ next <=dbo.get_strarraylength(@str,') begin print dbo.get_strarraystrofindex(@str,@ next ) set @ next =@ next +1 end |
调用结果:
1
2
3
4
5
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/pjymyself/article/details/81668157
- windows 安装解压版 mysql5.7.28 winx64的详细教程(windows 安装解压版 mysql5.7.28 winx64的详细教程)
- mysql服务器端安装步骤(windows下jsp+mysql网站环境配置方法)
- mysql索引分几种(MySQL 覆盖索引的优点)
- mysql索引知识点总结(MySQL 8.0 之索引跳跃扫描Index Skip Scan)
- mysql 查询语句group by用法(MySQL group by和order by如何一起使用)
- mysql数据库下载安装步骤(MySQL数据库压缩版本安装与配置详细教程)
- mysql索引详解及基本用法(Mysql普通索引与唯一索引的选择详析)
- 织梦源码安装数据库怎么填(Mysql修改端口号 织梦DedeCMS设置教程)
- mysql8.0.19.0正确安装图解(MySQL 8.0.23 主要更新一览新特征解读)
- 怎么运行xampp中的mysql(本地安装了mysql导致xampp的mysql服务启动失败)
- mysql中查询数据合并(Mysql合并结果接横向拼接字段的实现步骤)
- mysqlexplain的用法(MySQL SHOW STATUS语句的使用)
- mysql自增锁(深入剖析 MySQL 自增锁)
- 如何用mysql建立图书管理系统(图书管理系统的sqlserver数据库设计示例)
- mysql left join索引怎么使用(详解mysql 使用left join添加where条件的问题分析)
- mysql完整教程(MySql新手入门的基本操作汇总)
- 全球科技界最有钱大佬TOP 15 你知道几位(全球科技界最有钱大佬TOP)
- 2主力后腰缺阵 泰山队奇兵有望获重用,赛季0出场,迎来中超首秀(泰山队奇兵有望获重用)
- 三分71 生死战爆发 篮网旧将丁威迪今天成奇兵,助队赢球(三分71生死战爆发)
- 《红 雄安》系列广播剧第一集 水上奇兵雁翎队(雄安系列广播剧第一集)
- 小说 小伙穿越成刘备,用现代知识指挥作战,众谋士都看呆了(小伙穿越成刘备)
- 解析葡萄牙6-1瑞士 进攻多点开花,贡萨洛-拉莫斯一战成名(解析葡萄牙6-1瑞士)
热门推荐
- GridPanel中getSelectionModel
- linux中swap分区的作用是(linux swap交换分区详解)
- linux如何安装php环境(Linux下安装Memcached服务器和客户端与PHP使用示例)
- docker可以快速的创建和删除(Docker 命令自动补全的实现)
- vue自定义列组件(vue自定义表格列的实现过程记录)
- 如何通过广域网访问ftp服务器(Serv-u 外网访问内网的FTP服务器实现方法)
- phpinclude的使用方法(PHP defined函数的使用图文详解)
- 100道python真实面试题附答案(值得收藏的10道python 面试题)
- css如何使用z-index(CSS中的z-index属性基本使用教程)
- vue接收网络请求数据类型配置(vue中对接Graphql接口的实现示例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9