MySQL如何用分隔符分隔字符串
更新时间:2022年08月29日 14:02:25 作者:坚持与努力
这篇文章主要介绍了MySQL如何用分隔符分隔字符串,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
MySQL用分隔符分隔字符串
使用
可以使用如下函数
SUBSTRING_INDEX( i.final_car_type, ' ', 1 )
- i.final_car_type 即 需要分隔的字符串
- ’ ’ 即 用空格分隔该字符串
- 1 即:取出该空格之前的所有字符
也就是说,如果count是正数,那么就是从左往右数,第N个分隔符的左边的全部内容。相反,如果是负数,那么就是从右边开始数,第N个分隔符右边的所有内容
效果
如果count 是1
- 表里数据:东风风神全新AX7马赫版 DF 21(天窗版)
- 拆分后:东风风神全新AX7马赫版
如果count 是-1
- 表里数据:东风风神全新AX7马赫版 DF 21(天窗版)
- 拆分后:21(天窗版)
MySQL存储过程 根据分隔符拆分字符串
DELIMITER $$ CREATE DEFINER=`root`@`%` PROCEDURE `proc_split_Id`(in selectIds blob(65535), in splitChar varchar(2)) BEGIN set @i=0; CREATE TEMPORARY TABLE if not exists Id_Result_s(Id long NOT NULL); truncate table Id_Result_s; SET @cnt = 1+(LENGTH(selectIds) - LENGTH(REPLACE(selectIds,splitChar,''))); set @i=1; start transaction; WHILE @i <=@cnt DO SET @result = REPLACE(SUBSTRING(SUBSTRING_INDEX(selectIds, splitChar, @i), LENGTH(SUBSTRING_INDEX(selectIds, splitChar, @i -1)) + 1), splitChar, ''); INSERT INTO Id_Result_s(Id) VALUES (@result ); SET @i = @i + 1; END WHILE; commit; END
selectIds为需要拆分的字符串,splitChar为分隔符. 拆分的结果保存在临时表Id_Result_s中.
while中有insert语句,循环插入.在while前后加上start transaction和commit可以提高效率.
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
mysql问题之slow log中出现大量的binlog dump记录的解决方法
今天在查看mysql中发现比较慢,然后我使用了slow log,发现出现了大量的binlog dump记录,下面我来给大家整理一下这个问题的解决办法2013-09-09在SpringBoot中实现WebSocket会话管理的方案
在构建实时通信应用时,WebSocket 无疑是一个强大的工具,SpringBoot提供了对WebSocket的支持,本文旨在探讨如何在 Spring Boot 应用中实现 WebSocket 会话管理,我们将通过一个模拟的场景一步步展开讨论,需要的朋友可以参考下2023-11-11
最新评论