MySQL如何用分隔符分隔字符串

2022-08-29 14:41:17

目录MySQL用分隔符分隔字符串使用效果MySQL存储过程根据分隔符拆分字符串MySQL用分隔符分隔字符串使用可以使用如下函数SUBSTRING_INDEX(i.final_car_type,'...

目录
mysql用分隔符分隔字符串
使用
效果
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`@python`%` 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) js- 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_shttp://www.cppcns.com(Id) VALUES (@result );
SET @i = 编程@i + 1;   
    END WHILE;  
commit;    
END

selectIds为需要拆分的字符串,splitChar为分隔符. 拆分的结果保存在临时表Id_Result_s中.

while中有insert语句,循环插入.在while前后加上start transaction和commit可以提高效率.

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。