电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:5日期:2023-10-05 13:26:04
無(wú)分隔符的字符串截取

題目要求

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

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

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

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

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

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

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

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

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

二、替換函數(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’,’,’,’’)

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

三、獲取字符串長(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’)

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

實(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 表:

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

實(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

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

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

注:不含分隔符的字符串拆分可參考 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ò)誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 河南正规膏药生产厂家-膏药贴牌-膏药代加工-修康药业集团官网 | 农业四情_农业气象站_田间小型气象站_智慧农业气象站-山东风途物联网 | 【365公司转让网】公司求购|转让|资质买卖_股权转让交易平台 | 皮带机_移动皮带机_大倾角皮带机_皮带机厂家 - 新乡市国盛机械设备有限公司 | 自动售货机_无人售货机_专业的自动售货机运营商_免费投放售货机-广州富宏主官网 | 重庆LED显示屏_显示屏安装公司_重庆LED显示屏批发-彩光科技公司 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 上海地磅秤|电子地上衡|防爆地磅_上海地磅秤厂家–越衡称重 | 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 | 尾轮组_头轮组_矿用刮板_厢式刮板机_铸石刮板机厂家-双驰机械 | 铜镍-康铜-锰铜-电阻合金-NC003 - 杭州兴宇合金有限公司 | DDoS安全防护官网-领先的DDoS安全防护服务商 | 洗砂机械-球磨制砂机-洗沙制砂机械设备_青州冠诚重工机械有限公司 | 蓝牙音频分析仪-多功能-四通道-八通道音频分析仪-东莞市奥普新音频技术有限公司 | 云阳人才网_云阳招聘网_云阳人才市场_云阳人事人才网_云阳人家招聘网_云阳最新招聘信息 | 拉曼光谱仪_便携式|激光|显微共焦拉曼光谱仪-北京卓立汉光仪器有限公司 | 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 气体热式流量计-定量控制流量计(空气流量计厂家)-湖北南控仪表科技有限公司 | 标准品网_标准品信息网_【中检计量】 | 聚合氯化铝价格_聚合氯化铝厂家_pac絮凝剂-唐达净水官网 | 国际高中-国际学校-一站式择校服务-远播国际教育 | 不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰]-不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰] | 无刷电机_直流无刷电机_行星减速机-佛山市藤尺机电设备有限公司 无菌检查集菌仪,微生物限度仪器-苏州长留仪器百科 | PVC快速门-硬质快速门-洁净室快速门品牌厂家-苏州西朗门业 | 耐酸泵,耐腐蚀真空泵,耐酸真空泵-淄博华舜耐腐蚀真空泵有限公司 精密模具-双色注塑模具加工-深圳铭洋宇通 | 祝融环境-地源热泵多恒系统高新技术企业,舒适生活环境缔造者! | 博医通医疗器械互联网供应链服务平台_博医通 | 便携式XPDM露点仪-在线式防爆露点仪-增强型烟气分析仪-约克仪器 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | Dataforth隔离信号调理模块-信号放大模块-加速度振动传感器-北京康泰电子有限公司 | 交变/复合盐雾试验箱-高低温冲击试验箱_安奈设备产品供应杭州/江苏南京/安徽马鞍山合肥等全国各地 | 服务器之家 - 专注于服务器技术及软件下载分享 | 重庆网站建设,重庆网站设计,重庆网站制作,重庆seo,重庆做网站,重庆seo,重庆公众号运营,重庆小程序开发 | 伸缩节_伸缩器_传力接头_伸缩接头_巩义市联通管道厂 | 欧洲MV日韩MV国产_人妻无码一区二区三区免费_少妇被 到高潮喷出白浆av_精品少妇自慰到喷水AV网站 | 气象监测系统_气象传感器_微型气象仪_气象环境监测仪-山东风途物联网 | Trimos测长机_测高仪_TESA_mahr,WYLER水平仪,PWB对刀仪-德瑞华测量技术(苏州)有限公司 | 泰州物流公司_泰州货运公司_泰州物流专线-东鑫物流公司 | 网络推广公司_网络营销方案策划_企业网络推广外包平台-上海澜推网络 | 机械立体车库租赁_立体停车设备出租_智能停车场厂家_春华起重 | 清管器,管道清管器,聚氨酯发泡球,清管球 - 承德嘉拓设备 | EFM 022静电场测试仪-套帽式风量计-静电平板监测器-上海民仪电子有限公司 | 光谱仪_积分球_分布光度计_灯具检测生产厂家_杭州松朗光电【官网】 |