MySQL 字符串拆分操作(含分隔符的字符串截取)
題目要求
數(shù)據(jù)庫(kù)中字段值:
實(shí)現(xiàn)效果:需要將一行數(shù)據(jù)變成多行
實(shí)現(xiàn)的sql
SELECT LEFT(SUBSTRING(’P1111’,help_topic_id+1),1) AS num FROM mysql.help_topic WHERE help_topic_id < LENGTH(’P1111’);涉及的知識(shí)點(diǎn)一、字符串截取:SUBSTRING(str,pos)
1、參數(shù)說(shuō)明
參數(shù)名 解釋 str 需要拆分的字符串 delim 分隔符,通過(guò)某字符進(jìn)行拆分 count 當(dāng) count 為正數(shù),取第 n 個(gè)分隔符之前的所有字符; 當(dāng) count 為負(fù)數(shù),取倒數(shù)第 n 個(gè)分隔符之后的所有字符。2、 舉例
(1)獲取第2個(gè)以“,”逗號(hào)為分隔符之前的所有字符。
SUBSTRING_INDEX(’7654,7698,7782,7788’,’,’,2)
(2)獲取倒數(shù)第2個(gè)以“,”逗號(hào)分隔符之后的所有字符
SUBSTRING_INDEX(’7654,7698,7782,7788’,’,’,-2)
1、參數(shù)解說(shuō)
參數(shù)名 解釋 str 需要進(jìn)行替換的字符串 from_str 需要被替換的字符串 to_str 需要替換的字符串2、 舉例
(1)將分隔符“,”逗號(hào)替換為“”空。
REPLACE(’7654,7698,7782,7788’,’,’,’’)
1、參數(shù)解說(shuō)
參數(shù)名 解釋 str 需要計(jì)算長(zhǎng)度的字符串2、舉例
(1)獲取 ‘7654,7698,7782,7788’ 字符串的長(zhǎng)度
LENGTH(’7654,7698,7782,7788’)
實(shí)現(xiàn)的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 庫(kù)的 help_topic 表的 help_topic_id 來(lái)作為變量,因?yàn)?help_topic_id 是自增的,當(dāng)然也可以用其他表的自增字段輔助。
help_topic 表:
實(shí)現(xiàn)步驟:
Step1:首先獲取最后需被拆分成多少個(gè)字符串,利用 help_topic_id 來(lái)模擬遍歷 第n個(gè)字符串。
涉及的代碼片段:
help_topic_id < LENGTH(’7654,7698,7782,7788’)-LENGTH(REPLACE(’7654,7698,7782,7788’,’,’,’’))+1
Step2:根據(jù)“,”逗號(hào)來(lái)拆分字符串,此處利用 SUBSTRING_INDEX(str, delim, count) 函數(shù),最后把結(jié)果賦值給 num 字段。
涉及的代碼片段:
SUBSTRING_INDEX(SUBSTRING_INDEX(’7654,7698,7782,7788’,’,’,help_topic_id+1),’,’,-1) AS num
第一步:
以”,”逗號(hào)為分隔符,根據(jù) help_topic_id 的值來(lái)截取第n+1個(gè)分隔符之前所有的字符串。 (此處 n+1 是因?yàn)閔elp_topic_id 是從0開(kāi)始算起,而此處需從第1個(gè)分隔符開(kāi)始獲取。)
SUBSTRING_INDEX(’7654,7698,7782,7788’,’,’,help_topic_id+1)
eg:
當(dāng) help_topic_id = 0時(shí),獲取到的字符串 = 7654
當(dāng) help_topic_id = 1時(shí),獲取到的字符串 = 7654,7698
…(以此類推)
第二步:
以”,”逗號(hào)為分隔符,截取倒數(shù)第1個(gè)分隔符之后的所有字符串。
SUBSTRING_INDEX(SUBSTRING_INDEX(’7654,7698,7782,7788’,’,’,help_topic_id+1),’,’,-1)
eg:
根據(jù)第一步,當(dāng) help_topic_id = 0時(shí),獲取到的字符串 = 7654,此時(shí)第二步截取的字符串 = 7654
根據(jù)第一步,當(dāng) help_topic_id = 1時(shí),獲取到的字符串 = 7654,7698,此時(shí)第二步截取的字符串 = 7698
…(以此類推)
最終成功實(shí)現(xiàn)了以下效果 ~
注:不含分隔符的字符串拆分可參考 MySQL——字符串拆分(無(wú)分隔符的字符串截取)
補(bǔ)充:mysql字段分隔符拆分_MySQL里實(shí)現(xiàn)類似SPLIT的分割字符串的函數(shù)
下邊的函數(shù),實(shí)現(xiàn)了象數(shù)組一樣去處理字符串。
一、用臨時(shí)表作為數(shù)組create function f_split(@c varchar(2000),@split varchar(2))returns @t table(col varchar(20))asbeginwhile(charindex(@split,@c)<>0)begininsert @t(col) values (substring(@c,1,charindex(@split,@c)-1))set @c = stuff(@c,@c),’’)endinsert @t(col) values (@c)returnendgoselect * from dbo.f_split(’dfkd,dfdkdf,dfdkf,dffjk’,’,’)drop function f_splitcol--------------------dfkddfdkdfdfdkfdffjk
(所影響的行數(shù)為 4 行)
二、按指定符號(hào)分割字符串返回分割后的元素個(gè)數(shù),方法很簡(jiǎn)單,就是看字符串中存在多少個(gè)分隔符號(hào),然后再加一,就是要求的結(jié)果。
CREATE function Get_StrArrayLength(@str varchar(1024),--要分割的字符串@split varchar(10) --分隔符號(hào))returns intasbegindeclare @location intdeclare @start intdeclare @length intset @str=ltrim(rtrim(@str))set @location=charindex(@split,@str)set @length=1while @location<>0beginset @start=@location+1set @location=charindex(@split,@str,@start)set @length=@length+1endreturn @lengthend
調(diào)用示例:
select dbo.Get_StrArrayLength(’78,2,3’,’)
返回值:4
三、按指定符號(hào)分割字符串返回分割后指定索引的第幾個(gè)元素,象數(shù)組一樣方便
CREATE function Get_StrArrayStrOfIndex(@str varchar(1024),--要分割的字符串@split varchar(10),--分隔符號(hào)@index int --取第幾個(gè)元素)returns varchar(1024)asbegindeclare @location intdeclare @start intdeclare @next intdeclare @seed intset @str=ltrim(rtrim(@str))set @start=1set @next=1set @seed=len(@split)set @location=charindex(@split,@str)while @location<>0 and @index>@nextbeginset @start=@location+@seedset @location=charindex(@split,@start)set @next=@next+1endif @location =0 select @location =len(@str)+1--這兒存在兩種情況:1、字符串不存在分隔符號(hào) 2、字符串中存在分隔符號(hào),跳出while循環(huán)后,@location為0,那默認(rèn)為字符串后邊有一個(gè)分隔符號(hào)。return substring(@str,@start,@location-@start)end
調(diào)用示例:
select dbo.Get_StrArrayStrOfIndex(’8,9,4’,2)
返回值:9
四、結(jié)合上邊兩個(gè)函數(shù),象數(shù)組一樣遍歷字符串中的元素declare @str varchar(50)set @str=’1,3,4,5’declare @next intset @next=1while @next<=dbo.Get_StrArrayLength(@str,’)beginprint dbo.Get_StrArrayStrOfIndex(@str,@next)set @next=@next+1end
調(diào)用結(jié)果:
1
2
3
4
5
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. sql語(yǔ)句LEFT JOIN拼接表詳解2. C# 連接Access數(shù)據(jù)時(shí)總報(bào)找不到dbo.mdb的問(wèn)題3. Mysql優(yōu)化方法詳細(xì)介紹4. SQLServer創(chuàng)建索引的5種方法小結(jié)5. MySQL字段為 NULL的5大坑6. SQLite3 命令行操作指南7. MySQL實(shí)現(xiàn)批量推送數(shù)據(jù)到Mongo8. SQLite 性能優(yōu)化實(shí)例分享9. SQLite教程(二):C/C++接口簡(jiǎn)介10. SQLite中的WAL機(jī)制詳細(xì)介紹
