欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2021年02月22日 11:09:20   作者:pjymyself  
這篇文章主要介紹了MySQL 字符串拆分操作(含分隔符的字符串截取),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧

無(wú)分隔符的字符串截取

題目要求

數(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)

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

1、參數(shù)說(shuō)明

參數(shù)名 解釋
str 需要拆分的字符串
delim 分隔符,通過某字符進(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)

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

1、參數(shù)解說(shuō)

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

2、 舉例

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

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

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

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開始算起,而此處需從第1個(gè)分隔符開始獲取。)

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ú)分隔符的字符串截?。?/p>

補(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))
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 行)

二、按指定符號(hào)分割字符串

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

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

三、按指定符號(hào)分割字符串

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

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

調(diào)用結(jié)果:

1

2

3

4

5

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • 在sql中實(shí)現(xiàn)取一行最大值或者最小值

    在sql中實(shí)現(xiàn)取一行最大值或者最小值

    這篇文章主要介紹了在sql中實(shí)現(xiàn)取一行最大值或者最小值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2020-12-12
  • MySQL分組查詢、排序查詢、分頁(yè)查詢以及執(zhí)行順序

    MySQL分組查詢、排序查詢、分頁(yè)查詢以及執(zhí)行順序

    MySQL數(shù)據(jù)查詢是數(shù)據(jù)庫(kù)操作中最常見的操作之一,它可以幫助我們從數(shù)據(jù)庫(kù)中獲取所需的數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于MySQL分組查詢、排序查詢、分頁(yè)查詢以及執(zhí)行順序的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • SQL中"1=1"的陷阱:為什么應(yīng)避免使用

    SQL中"1=1"的陷阱:為什么應(yīng)避免使用

    "1=1"在SQL中可能看似無(wú)害,但它卻是一個(gè)隱藏的陷阱,這個(gè)簡(jiǎn)單的表達(dá)式可能會(huì)導(dǎo)致你的查詢結(jié)果出現(xiàn)偏差,甚至可能引發(fā)安全問題,本指南將揭示這個(gè)陷阱,教你如何避免使用"1=1",讓你的數(shù)據(jù)庫(kù)操作更加安全、準(zhǔn)確,讓我們一起揭開"1=1"的秘密,提升你的SQL技能!
    2024-02-02
  • MySQL使用binlog日志回滾操作失誤的數(shù)據(jù)的操作教程

    MySQL使用binlog日志回滾操作失誤的數(shù)據(jù)的操作教程

    在日常開發(fā)運(yùn)維中,我們可能會(huì)出現(xiàn)一些操作失誤的情況,比如使用了錯(cuò)誤的 sql 語(yǔ)句對(duì) mysql 數(shù)據(jù)進(jìn)行了 update、delete 等操作,失誤操作導(dǎo)致數(shù)據(jù)出現(xiàn)問題,那么如果出現(xiàn)這種情況,應(yīng)該如何恢復(fù)失誤/mysql 誤刪數(shù)據(jù)時(shí),本文將使用幾種常用方法帶你回滾誤刪的數(shù)據(jù)
    2025-08-08
  • MySQL主從同步+binlog詳解

    MySQL主從同步+binlog詳解

    這篇文章主要介紹了MySQL主從同步+binlog的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-07-07
  • MySQL中查找重復(fù)值的實(shí)現(xiàn)

    MySQL中查找重復(fù)值的實(shí)現(xiàn)

    查找重復(fù)值是一項(xiàng)常見需求,比如在數(shù)據(jù)清理、數(shù)據(jù)分析、數(shù)據(jù)質(zhì)量檢查等場(chǎng)景下,我們常常需要找出表中某列或多列的重復(fù)值,具有一定的參考價(jià)值,感興趣的可以了解一下
    2025-07-07
  • mysql數(shù)據(jù)庫(kù)和oracle數(shù)據(jù)庫(kù)之間互相導(dǎo)入備份

    mysql數(shù)據(jù)庫(kù)和oracle數(shù)據(jù)庫(kù)之間互相導(dǎo)入備份

    今天小編就為大家分享一篇關(guān)于mysql數(shù)據(jù)庫(kù)和oracle數(shù)據(jù)庫(kù)之間互相導(dǎo)入備份,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-04-04
  • 解決mysql連接超時(shí)和mysql連接錯(cuò)誤的問題

    解決mysql連接超時(shí)和mysql連接錯(cuò)誤的問題

    這篇文章主要介紹了解決mysql連接超時(shí)和mysql連接錯(cuò)誤的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • MySQL中如何正確存儲(chǔ)IP地址

    MySQL中如何正確存儲(chǔ)IP地址

    在MySQL中,當(dāng)存儲(chǔ)IPv4地址時(shí),應(yīng)該使用32位的無(wú)符號(hào)整數(shù)(UNSIGNED INT)來(lái)存儲(chǔ)IP地址,而不是使用字符串,下面就來(lái)詳細(xì)的介紹一下具體原因,感興趣的可以了解一下
    2023-05-05
  • MySQL安裝第四步報(bào)錯(cuò)(initializing?database報(bào)錯(cuò))的圖文解決方法

    MySQL安裝第四步報(bào)錯(cuò)(initializing?database報(bào)錯(cuò))的圖文解決方法

    這篇文章主要給大家介紹了關(guān)于MySQL安裝第四步報(bào)錯(cuò)(initializing?database報(bào)錯(cuò))的解決方法,"initializing?database"?通常出現(xiàn)在安裝MySQL的過程中,表示MySQL數(shù)據(jù)庫(kù)初始化過程中遇到了問題,需要的朋友可以參考下
    2024-06-06

最新評(píng)論