溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql 字符串拆分并分組

發(fā)布時間:2021-02-22 17:02:51 來源:億速云 閱讀:4337 作者:戴恩恩 欄目:開發(fā)技術

這篇文章主要為大家詳細介紹了mysql 字符串拆分并分組,文中示例代碼介紹的非常詳細,具有一定的參考價值,發(fā)現(xiàn)的小伙伴們可以參考一下:

無分隔符的字符串截取

題目要求

數(shù)據(jù)庫中字段值:

mysql 字符串拆分并分組

實現(xiàn)效果:需要將一行數(shù)據(jù)變成多行

mysql 字符串拆分并分組

實現(xiàn)的sql

SELECT LEFT(SUBSTRING('P1111',help_topic_id+1),1) AS num FROM mysql.help_topic WHERE help_topic_id < LENGTH('P1111');

涉及的知識點

一、字符串截?。篠UBSTRING(str,pos)

1、參數(shù)說明

參數(shù)名解釋
str需要拆分的字符串
delim分隔符,通過某字符進行拆分
count當 count 為正數(shù),取第 n 個分隔符之前的所有字符; 當 count 為負數(shù),取倒數(shù)第 n 個分隔符之后的所有字符。

2、 舉例

(1)獲取第2個以“,”逗號為分隔符之前的所有字符。

SUBSTRING_INDEX('7654,7698,7782,7788',',',2)

mysql 字符串拆分并分組

(2)獲取倒數(shù)第2個以“,”逗號分隔符之后的所有字符

SUBSTRING_INDEX('7654,7698,7782,7788',',',-2)

mysql 字符串拆分并分組

二、替換函數(shù):replace( str, from_str, to_str)

1、參數(shù)解說

參數(shù)名解釋
str需要進行替換的字符串
from_str需要被替換的字符串
to_str需要替換的字符串

2、 舉例

(1)將分隔符“,”逗號替換為“”空。

REPLACE('7654,7698,7782,7788',',','')

mysql 字符串拆分并分組

三、獲取字符串長度:LENGTH( str )

1、參數(shù)解說

參數(shù)名解釋
str需要計算長度的字符串

2、舉例

(1)獲取 ‘7654,7698,7782,7788' 字符串的長度

LENGTH('7654,7698,7782,7788')

mysql 字符串拆分并分組

實現(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 庫的 help_topic 表的 help_topic_id 來作為變量,因為 help_topic_id 是自增的,當然也可以用其他表的自增字段輔助。

help_topic 表:

mysql 字符串拆分并分組

實現(xiàn)步驟:

Step1:首先獲取最后需被拆分成多少個字符串,利用 help_topic_id 來模擬遍歷 第n個字符串。

涉及的代碼片段:

help_topic_id < LENGTH('7654,7698,7782,7788')-LENGTH(REPLACE('7654,7698,7782,7788',',',''))+1

mysql 字符串拆分并分組

Step2:根據(jù)“,”逗號來拆分字符串,此處利用 SUBSTRING_INDEX(str, delim, count) 函數(shù),最后把結果賦值給 num 字段。

涉及的代碼片段:

SUBSTRING_INDEX(SUBSTRING_INDEX('7654,7698,7782,7788',',',help_topic_id+1),',',-1) AS num

第一步:

以”,”逗號為分隔符,根據(jù) 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

…(以此類推)

第二步:

以”,”逗號為分隔符,截取倒數(shù)第1個分隔符之后的所有字符串。

SUBSTRING_INDEX(SUBSTRING_INDEX('7654,7698,7782,7788',',',help_topic_id+1),',',-1)

eg:

根據(jù)第一步,當 help_topic_id = 0時,獲取到的字符串 = 7654,此時第二步截取的字符串 = 7654

根據(jù)第一步,當 help_topic_id = 1時,獲取到的字符串 = 7654,7698,此時第二步截取的字符串 = 7698

…(以此類推)

最終成功實現(xiàn)了以下效果 ~

mysql 字符串拆分并分組

注:不含分隔符的字符串拆分可參考 MySQL——字符串拆分(無分隔符的字符串截?。?/p>

補充:mysql字段分隔符拆分_MySQL里實現(xiàn)類似SPLIT的分割字符串的函數(shù)

下邊的函數(shù),實現(xiàn)了象數(shù)組一樣去處理字符串。

一、用臨時表作為數(shù)組

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

(所影響的行數(shù)為 4 行)

二、按指定符號分割字符串

返回分割后的元素個數(shù),方法很簡單,就是看字符串中存在多少個分隔符號,然后再加一,就是要求的結果。

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

調(diào)用示例:

select dbo.Get_StrArrayLength('78,2,3',')

返回值:4

三、按指定符號分割字符串

返回分割后指定索引的第幾個元素,象數(shù)組一樣方便

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循環(huán)后,@location為0,那默認為字符串后邊有一個分隔符號。
return substring(@str,@start,@location-@start)
end

調(diào)用示例:

select dbo.Get_StrArrayStrOfIndex('8,9,4',2)

返回值:9

四、結合上邊兩個函數(shù),象數(shù)組一樣遍歷字符串中的元素

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

調(diào)用結果:

1

2

3

4

5

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI