首頁  >  文章  >  資料庫  >  MySQL怎麼用分隔符號分隔字串

MySQL怎麼用分隔符號分隔字串

PHPz
PHPz轉載
2023-06-01 08:43:172010瀏覽

    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刪除