温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL怎么用分隔符分隔字符串

发布时间:2022-08-29 16:24:03 来源:亿速云 阅读:160 作者:iii 栏目:开发技术

本篇内容主要讲解“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`@`%` 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怎么用分隔符分隔字符串”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI