MySQL用分隔符分隔字符串
使用
可以使用如下函数
SUBSTRING_INDEX( i.final_car_type, ' ', 1 )
i.final_car_type 即 需要分隔的字符串
’ ’ 即 用空格分隔该字符串
1 即:取出该空格之前的所有字符
如果count为正数,那么所得结果为从左到右数第N个分隔符左侧的所有内容。如果为负数,则表示从右边开始计算,取第N个分隔符右侧的所有内容
效果
如果count 是1
表里数据:东风风神全新AX7马赫版 DF 21(天窗版)
拆分后:东风风神全新AX7马赫版
阿里云-虚拟数字人
阿里云-虚拟数字人是什么? …
2 查看详情
如果count 是-1
表里数据:东风风神全新AX7马赫版 DF 21(天窗版)
拆分后:21(天窗版)
MySQL存储过程 根据分隔符拆分字符串
DELIMITER $$ CREATE DEFINER=`root`@`%` PROCEDURE `proc_split_Id`(in selectIds blob(65535),in splitChar varchar(2))BEGINset @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怎么用分隔符分隔字符串的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/264104.html
微信扫一扫
支付宝扫一扫