MySQL 自定义 split 存储过程

MySQL 没有提供 split 函数,但可以自己建立一个存储过程,将具有固定分隔符的字符串转成多行。之所以不能使用自定义函数实现此功能,是因为 MySQL 的自定义函数自能返回标量值,不能返回多行结果集。

MySQL 8:

复制代码
drop procedure if exists sp_split;
delimiter //
create procedure sp_split(p_str text, p_delimiter varchar(100))
begin
    select substring_index(substring_index(p_str, p_delimiter, lv), p_delimiter, - 1) a
      from (
	  with recursive tab1(lv) as (
           select 1 lv 
            union all
           select t1.lv + 1 from tab1 t1 
            where lv < (char_length(p_str) - char_length(replace(p_str, p_delimiter, ''))) / (char_length(p_delimiter)) + 1)
      select * from tab1
      ) t1;
end;
//
delimiter ;

MySQL 5:

复制代码
drop procedure if exists sp_split;
delimiter //
create procedure sp_split(p_str text, p_delimiter varchar(100))
begin
    select substring_index(substring_index(p_str, p_delimiter, help_topic_id + 1), p_delimiter, - 1) a
      from mysql.help_topic  
     where help_topic_id < (char_length(p_str) - char_length(replace(p_str, p_delimiter, ''))) / (char_length(p_delimiter)) + 1;
end;
//
delimiter ;

测试:

复制代码
mysql> set @a:='123,456,789';
Query OK, 0 rows affected (0.00 sec)

mysql> call sp_split(@a,',');
+------+
| a    |
+------+
| 123  |
| 456  |
| 789  |
+------+
3 rows in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)

mysql> set @a:='中;;English;;混杂;;多字符分隔符';
Query OK, 0 rows affected (0.00 sec)

mysql> call sp_split(@a,';;');
+--------------------+
| a                  |
+--------------------+
| 中                 |
| English            |
| 混杂               |
| 多字符分隔符        |
+--------------------+
4 rows in set (0.00 sec)

Query OK, 0 rows affected (0.00 sec)
相关推荐
Magic--12 分钟前
进程间通信(IPC):原理、场景与选型
java·服务器·数据库
xhuiting21 分钟前
MySQL专题总结(三)—— 补充篇
数据库·mysql
智象科技38 分钟前
告警自动化赋能运维:意义与价值解析
网络·数据库·人工智能·自动化·告警·一体化运维·ai运维
源远流长jerry39 分钟前
在云环境中部署 NFV:OpenStack 讲解
数据库·openstack
※DX3906※39 分钟前
SpringBoot之旅4: MyBatis 操作数据库(进阶) 动态SQL+MyBatis-Plus实战,从入门到熟练,再也不踩绑定异常、SQL拼接坑
java·数据库·spring boot·spring·java-ee·maven·mybatis
J超会运1 小时前
OpenEuler系统MySQL备份恢复全攻略
mysql·mysql备份
Carino_U1 小时前
全面理解mysql架构
mysql·adb·架构
小的~~1 小时前
使用StreamLoad向Doris-4.0.3版本的聚合表导数据超时问题
运维·服务器·数据库
笑梦无境1 小时前
mysql基础篇一(多年前整理)
数据库·mysql
Yushan Bai1 小时前
HP-UX平台Oracle启动实例遭遇ORA-27300/ORA-27301/ORA-27302报错
数据库·oracle·ux