MySQL 字符串拆分操作(含分隔符的字符串截取)
无分隔符的字符串截取
题目要求
数据库中字段值:
实现效果:需要将一行数据变成多行
实现的sql
SELECTLEFT(SUBSTRING('P1111',help_topic_id+1),1)ASnumFROMmysql.help_topicWHEREhelp_topic_id涉及的知识点
一、字符串截取: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)ASnum FROM mysql.help_topic WHERE help_topic_id此处利用mysql库的help_topic表的help_topic_id来作为变量,因为help_topic_id是自增的,当然也可以用其他表的自增字段辅助。
help_topic表:
实现步骤:
Step1:首先获取最后需被拆分成多少个字符串,利用help_topic_id来模拟遍历第n个字符串。
涉及的代码片段:
help_topic_id
Step2:根据“,”逗号来拆分字符串,此处利用SUBSTRING_INDEX(str,delim,count)函数,最后把结果赋值给num字段。
涉及的代码片段:
SUBSTRING_INDEX(SUBSTRING_INDEX('7654,7698,7782,7788',',',help_topic_id+1),',',-1)ASnum第一步:
以”,”逗号为分隔符,根据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的分割字符串的函数
下边的函数,实现了象数组一样去处理字符串。
一、用临时表作为数组
createfunctionf_split(@cvarchar(2000),@splitvarchar(2)) returns@ttable(colvarchar(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*fromdbo.f_split('dfkd,dfdkdf,dfdkf,dffjk',',') dropfunctionf_split col -------------------- dfkd dfdkdf dfdkf dffjk(所影响的行数为4行)
二、按指定符号分割字符串
返回分割后的元素个数,方法很简单,就是看字符串中存在多少个分隔符号,然后再加一,就是要求的结果。
CREATEfunctionGet_StrArrayLength ( @strvarchar(1024),--要分割的字符串 @splitvarchar(10)--分隔符号 ) returnsint as begin declare@locationint declare@startint declare@lengthint 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调用示例:
selectdbo.Get_StrArrayLength('78,2,3',')返回值:4
三、按指定符号分割字符串
返回分割后指定索引的第几个元素,象数组一样方便
CREATEfunctionGet_StrArrayStrOfIndex ( @strvarchar(1024),--要分割的字符串 @splitvarchar(10),--分隔符号 @indexint--取第几个元素 ) returnsvarchar(1024) as begin declare@locationint declare@startint declare@nextint declare@seedint set@str=ltrim(rtrim(@str)) set@start=1 set@next=1 set@seed=len(@split) set@location=charindex(@split,@str) while@location<>0and@index>@next begin set@start=@location+@seed set@location=charindex(@split,@start) set@next=@next+1 end if@location=0select@location=len(@str)+1 --这儿存在两种情况:1、字符串不存在分隔符号2、字符串中存在分隔符号,跳出while循环后,@location为0,那默认为字符串后边有一个分隔符号。 returnsubstring(@str,@start,@location-@start) end调用示例:
selectdbo.Get_StrArrayStrOfIndex('8,9,4',2)返回值:9
四、结合上边两个函数,象数组一样遍历字符串中的元素
declare@strvarchar(50) set@str='1,3,4,5' declare@nextint set@next=1 while@next<=dbo.Get_StrArrayLength(@str,') begin printdbo.Get_StrArrayStrOfIndex(@str,@next) set@next=@next+1 end调用结果:
1
2
3
4
5
以上为个人经验,希望能给大家一个参考,也希望大家多多支持毛票票。如有错误或未考虑完全的地方,望不吝赐教。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。