日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL 字符串拆分操作(含分隔符的字符串截取)

瀏覽:46日期:2023-10-05 13:26:04
無分隔符的字符串截取

題目要求

數據庫中字段值:

MySQL 字符串拆分操作(含分隔符的字符串截取)

實現效果:需要將一行數據變成多行

MySQL 字符串拆分操作(含分隔符的字符串截取)

實現的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、參數說明

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

2、 舉例

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

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

MySQL 字符串拆分操作(含分隔符的字符串截取)

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

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

MySQL 字符串拆分操作(含分隔符的字符串截取)

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

1、參數解說

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

2、 舉例

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

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

MySQL 字符串拆分操作(含分隔符的字符串截取)

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

1、參數解說

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

2、舉例

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

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

MySQL 字符串拆分操作(含分隔符的字符串截取)

實現的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 字符串拆分操作(含分隔符的字符串截取)

實現步驟:

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

涉及的代碼片段:

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

MySQL 字符串拆分操作(含分隔符的字符串截取)

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——字符串拆分(無分隔符的字符串截?。?/p>

補充:mysql字段分隔符拆分_MySQL里實現類似SPLIT的分割字符串的函數

下邊的函數,實現了象數組一樣去處理字符串。

一、用臨時表作為數組

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

(所影響的行數為 4 行)

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

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

CREATE function Get_StrArrayLength(@str varchar(1024),--要分割的字符串@split varchar(10) --分隔符號)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

調用示例:

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

返回值:4

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

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

CREATE function Get_StrArrayStrOfIndex(@str varchar(1024),--要分割的字符串@split varchar(10),--分隔符號@index int --取第幾個元素)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、字符串不存在分隔符號 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 intset @next=1while @next<=dbo.Get_StrArrayLength(@str,’)beginprint dbo.Get_StrArrayStrOfIndex(@str,@next)set @next=@next+1end

調用結果:

1

2

3

4

5

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本国产亚洲| 久久久亚洲一区| 伊人久久在线| 成人国产精品一区二区免费麻豆| 亚洲人亚洲人色久| 欧美专区18| 国产精品腿扒开做爽爽爽挤奶网站| 卡一卡二国产精品| 欧美激情一区| 国产精品久久久久9999高清| 日韩精品三区四区| 7m精品国产导航在线| 日韩午夜视频在线| 国产亚洲电影| 开心激情综合| 日本久久成人网| 99视频精品全国免费| 成人日韩在线观看| 99亚洲视频| 婷婷精品在线| 精品一二三区| 成人av二区| 夜夜嗨一区二区三区| 爽好久久久欧美精品| 日韩高清一区在线| 你懂的国产精品永久在线| av综合电影网站| 欧美日韩日本国产亚洲在线| 亚洲免费专区| 国产区精品区| 日韩精品欧美| 日韩av黄色在线| 精精国产xxxx视频在线野外| 国产精品日本欧美一区二区三区| 亚洲精品极品| 日韩在线观看一区| 亚洲欧美专区| 视频一区中文字幕| 97se综合| 亚洲开心激情| 激情国产在线| 亚洲欧美网站在线观看| 韩日一区二区| 亚洲精品乱码久久久久久蜜桃麻豆| 国产美女精品视频免费播放软件| 亚洲伦乱视频| 亚洲精品伊人| 欧美偷窥清纯综合图区| 国产精品欧美三级在线观看| 99久久夜色精品国产亚洲狼| 免费日本视频一区| 肉色欧美久久久久久久免费看| 午夜日本精品| 国产成人久久精品麻豆二区| 免费看的黄色欧美网站| 欧美成a人片免费观看久久五月天| 在线成人直播| 日韩欧美综合| 精品久久久久中文字幕小说| 日韩精品一区二区三区中文| 午夜国产精品视频| 国产麻豆久久| 国产一区日韩| 国产极品嫩模在线观看91精品| 最新国产精品视频| 美女精品在线| 国产精品腿扒开做爽爽爽挤奶网站| 特黄毛片在线观看| 久久精品 人人爱| 日韩激情啪啪| 日韩国产在线一| 四虎精品永久免费| 免费精品视频最新在线| 亚洲午夜电影| 午夜国产欧美理论在线播放| 久久人人99| 在线日韩一区| 日韩中文欧美在线| 日韩精品亚洲专区| 青草综合视频| 日本不卡不码高清免费观看| 日本在线成人| 久久中文字幕一区二区| 国产精品中文字幕制服诱惑| 国产精品美女在线观看直播| 精品视频一区二区三区在线观看| 久久三级毛片| 色天使综合视频| 噜噜噜久久亚洲精品国产品小说| 亚洲专区一区| 日韩高清在线观看一区二区| 国产精品一区二区中文字幕| 精品91福利视频| 久久蜜桃精品| 亚洲欧洲国产精品一区| 欧美a一区二区| 婷婷久久一区| 日韩国产在线一| 国产精品tv| 免费视频亚洲| 国产精品一区高清| 久久高清免费| 欧美久久久网站| 免费av一区二区三区四区| 五月亚洲婷婷 | 视频一区欧美精品| 精品美女在线视频| 综合亚洲自拍| 999国产精品| 日韩不卡一区二区| 影音先锋国产精品| 神马午夜久久| 国产一区二区久久久久| 日本精品国产| 免费人成精品欧美精品| 午夜欧美巨大性欧美巨大| 日韩欧美三区| 蜜臀久久久99精品久久久久久| 久久久精品网| 正在播放日韩精品| 国产精品观看| 日韩国产欧美在线视频| 欧美成人精品| 亚洲自拍另类| 九九99久久精品在免费线bt| 91九色精品| 欧美成a人片免费观看久久五月天| 久久福利精品| 新版的欧美在线视频| 日韩va亚洲va欧美va久久| 久久久久久久久久久妇女 | 中文不卡在线| 美女精品一区二区| 日本中文字幕视频一区| 欧美羞羞视频| 国产精品色在线网站| 免费不卡在线观看| 视频福利一区| 国产欧美成人| 午夜久久av| 日韩专区欧美专区| 精品欧美激情在线观看| 六月婷婷综合| 日本午夜大片a在线观看| 久久gogo国模啪啪裸体| 日本综合视频| 在线精品一区二区| 99综合视频| 亚洲性色视频| 日韩一区精品| 日本在线视频一区二区| 亚洲a成人v| 日本综合精品一区| 国产午夜精品一区二区三区欧美| 精品在线网站观看| 国产不卡精品| 日韩av一级| 欧美久久精品一级c片| 欧美精品一区二区三区精品| 免费不卡中文字幕在线| 午夜国产精品视频| 免费成人在线影院| 九九久久国产| 九色porny丨国产首页在线| 久久精品主播| 免费人成黄页网站在线一区二区| 蜜桃视频欧美| 欧美aa在线视频| 国产 日韩 欧美 综合 一区| 午夜久久中文| 免费欧美一区| 免费人成精品欧美精品| 狠狠久久伊人| 六月婷婷一区| 国产精品久久免费视频| 999视频精品| 日本va欧美va精品发布| 欧美激情三区| 不卡中文字幕| 91精品尤物| 亚洲韩日在线| 亚洲黄色免费看| 首页亚洲欧美制服丝腿| 国产91久久精品一区二区| 热久久久久久久| 亚洲女同一区| 日韩精品中文字幕第1页| 欧美永久精品| 91亚洲一区| 国产日产精品_国产精品毛片 | 国产精品久久久免费| 亚洲伦乱视频| 久久精品97| 日韩国产精品久久久| 国产真实久久| 国产成人精品免费视| 日韩精品一级| 国产精品美女| 色偷偷偷在线视频播放| 国产精品中文|