MySQL用分隔符分隔字符串
使用
可以使用如下函数
- 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;    
ENDselectIds为需要拆分的字符串,splitChar为分隔符. 拆分的结果保存在临时表Id_Result_s中.
while中有insert语句,循环插入.在while前后加上start transaction和commit可以提高效率.