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

PHPz
发布: 2023-06-01 08:43:17
转载
2047 人浏览过

    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, &#39;&#39;);  
           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怎么用分隔符分隔字符串的详细内容。更多信息请关注PHP中文网其他相关文章!

    相关标签:
    来源:yisu.com
    本站声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板