mysql函数split功能实现

所属分类: 数据库 / Mysql 阅读数: 1170
收藏 0 赞 0 分享
先设置:SET GLOBAL log_bin_trust_function_creators = 1;

1. 函数func_splitStringTotal:将字符串按指定方式分割,并计算单元总数

复制代码 代码如下:

DELIMITER $$
CREATE FUNCTION `func_get_splitStringTotal`(
f_string varchar(10000),f_delimiter varchar(50)
) RETURNS int(11)
BEGIN
return 1+(length(f_string) - length(replace(f_string,f_delimiter,'')));
END$$
DELIMITER ;


2.函数func_splitString:将字符串按指定方式分割,获取指定位置的数

复制代码 代码如下:

DELIMITER $$
DROP function IF EXISTS `func_splitString` $$
CREATE FUNCTION `func_splitString`
( f_string varchar(1000),f_delimiter varchar(5),f_order int)
RETURNS varchar(255) CHARSET utf8
BEGIN

declare result varchar(255) default '';
set result = reverse(substring_index(reverse(substring_index(f_string,f_delimiter,f_order)),f_delimiter,1));
return result;
END$$
SELECT func_splitString('1,2,3,4,5,6,7',',',1);


3.过程splitString 将字符串分割,并放到临时表tmp_split 里面

复制代码 代码如下:

DELIMITER $$
DROP PROCEDURE IF EXISTS `splitString` $$
CREATE PROCEDURE `splitString`
(IN f_string varchar(1000),IN f_delimiter varchar(5))

BEGIN
declare cnt int default 0;
declare i int default 0;
set cnt = func_split_TotalLength(f_string,f_delimiter);
DROP TABLE IF EXISTS `tmp_split`;
create temporary table `tmp_split` (`val_` varchar(128) not null) DEFAULT CHARSET=utf8;

while i < cnt
do
set i = i + 1;
insert into tmp_split(`val_`) values (func_split(f_string,f_delimiter,i));
end while;
END$$
call splitString('a,s,d,f,g,h,j',',');
SELECT * from tmp_split;
更多精彩内容其他人还在看

MySQL的日志基础知识及基本操作学习教程

这篇文章主要介绍了MySQL的日志基础知识学习教程,包括MySQL中日志相关常用的服务器变量说明,极力推荐!需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL入门完全指南及Linux系统下基本的安装教程

这篇文章主要介绍了MySQL入门完全指南及Linux系统下基本的安装教程,对MySQL的基本特性有一个较为详细的整理,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL针对Discuz论坛程序的基本优化教程

这篇文章主要介绍了MySQL针对Discuz论坛程序的基本优化教程,包括在缓存和索引等方面的优化方法,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL的InnoDB引擎入门学习教程

这篇文章主要介绍了MySQL的InnoDB引擎入门学习教程,对InnoDB的存储结构有一个较好的总结,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL下常见的启动失败与备份失败问题的解决教程

这篇文章主要介绍了MySQL下常见的启动失败与备份失败问题的解决教程,示例环境基于Linux系统,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL日志分析软件mysqlsla的安装和使用教程

这篇文章主要介绍了MySQL日志分析软件mysqlsla的安装和使用教程,文中以Linux系统作为环境进行示例,需要的朋友可以参考下
收藏 0 赞 0 分享

修改MySQL的默认密码的四种小方法

对于windows平台来说安装完MySQL后,系统就已经默认生成了许可表和账户,下文中就教给大家如何修改MySQ的默认密码。
收藏 0 赞 0 分享

傻瓜式用Eclipse连接MySQL数据库

本来不想写这么简单人文章,在百度上搜索我这个标题,完全符合标题的一大堆。但我按照那些文章捣鼓了很久,就是不行。
收藏 0 赞 0 分享

修改MySQL的数据库引擎为INNODB的方法

本文主要介绍了修改MySQL的数据库引擎为INNODB的方法,希望能对您有所帮助。
收藏 0 赞 0 分享

Mysql数据库命令大全

mysql命令大家经常会用到,但是很少有朋友整理吧,最近项目不多,抽个时间把mysql数据库命令总结给大家,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多