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

吾爱主题 阅读:115 2024-04-01 23:21:56 评论:0

MySQL用分隔符分隔字符串

使用

可以使用如下函数

?
1 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存储过程 根据分隔符拆分字符串

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 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可以提高效率.

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/a984171281/article/details/124626500

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容