MySQL如何用分隔符分隔字符串 目录 MySQL用分隔符分隔字符串 使用 效果 MySQL存储过程 根据分隔符拆分字符串 MySQL用分隔符分隔字符串 使用 可以使用如下函数 SUBSTRING_INDEX( i.final_car_type, ' ', 1 ) i.final_car_type 即 需要分隔的字符串 ’ ’ 即 用空格分隔
目录
- 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如何用分隔符分隔字符串
基础教程推荐
猜你喜欢
- python中pandas库的iloc函数用法解析 2023-07-28
- Sql Server Management Studio连接Mysql的实现步骤 2023-07-29
- 关于MySQL中explain工具的使用 2023-07-27
- Mysql查询所有表和字段信息的方法 2023-07-26
- Python常见库matplotlib学习笔记之多个子图绘图 2023-07-27
- Redis如何实现延迟队列 2023-07-13
- 【Redis】数据持久化 2023-09-12
- SQLServer 清理日志的实现 2023-07-29
- 如何将excel表格数据导入postgresql数据库 2023-07-20
- Mysql主从三种复制模式(异步复制,半同步复制,组复 2022-09-01