MySQL 字符串拆分实例(无分隔符的字符串截取)

 更新时间:2021年02月22日 11:24:55   作者:pjymyself  
这篇文章主要介绍了MySQL 字符串拆分实例(无分隔符的字符串截取),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

无分隔符的字符串截取

题目要求

数据库中字段值:

实现效果:需要将一行数据变成多行

实现的sql

SELECT LEFT(SUBSTRING('P1111',help_topic_id+1),1) AS num FROM mysql.help_topic WHERE help_topic_id < LENGTH('P1111');

涉及的知识点

一、字符串截取:SUBSTRING(str,pos)

1、参数说明

参数名 解释
str 被截取的字符串
pos 从第几位开始截取,当 pos 为正数时,表示从字符串开始第 pos 位开始取,直到结束;当pos为负数时,表示从字符串倒数第 pos位开始取,直到结束。

2、 举例

(一)从第2个字符开始获取字符串'P1111'

SUBSTRING('P1111',2)

(二)从倒数第2个字符开始获取字符串'P1111'

SUBSTRING('P1111',-2)

二、从左边开始截取字符串:LEFT(str,len)

1、参数说明

参数名 解释
str 被截取的字符串
len 正整数,表示截取字符串从最左边开始到第 len 位的值。

2、举例

(一) 获取字符串'P1111'最左边的3个字符

LEFT('P1111',3)

Tip:

有从左边开始截取字符串的函数 LEFT(str,len),那当然也有从右边开始截取字符串的 RIGHT(str,len), 左右两个函数原理一样,区别在于是从左边开始还是右边开始截取字符串。

SQL解析

SELECT LEFT(SUBSTRING('P1111',help_topic_id+1),1) AS num FROM mysql.help_topic WHERE help_topic_id < LENGTH('P1111');

此处同样利用 mysql 库的 help_topic 表的 help_topic_id 来作为变量,因为 help_topic_id 是自增的,当然也可以用其他表的自增字段辅助。

可参考 MySQL——字符串拆分(一)

实现步骤

Step1:

获取字符串 ‘P1111' 的长度,利用 help_topic_id 来动态模拟对字符串 ‘P1111' 的遍历

help_topic_id < LENGTH('P1111')

Step2:

利用 SUBSTRING(str,pos) 函数 和 help_topic_id 对字符串 ‘P1111' 进行截取。(此处“help_topic_id+1”的原因是 help_topic_id 是从0开始的,而 SUBSTRING 函数需从第1个位置开始截取字符串)

SUBSTRING('P1111',help_topic_id+1)

eg:

当 help_topic_id = 0 时,获取到的字符串 = P1111

当 help_topic_id = 1 时,获取到的字符串 = 1111

…(以此类推)

Step3:在实现第2步的基础上,结合 LEFT(str,len) 函数来获取第2步中最左边的第1个字符

LEFT(SUBSTRING('P1111',help_topic_id+1),1)

eg:

根据第2步,当 help_topic_id = 0 时,获取到的字符串 = P1111,此时第3步获取的字符串 = P

根据第2步,当 help_topic_id = 1 时,获取到的字符串 = 1111,此时第3步获取的字符串 = 1

…(以此类推)

最终成功实现以下效果

注:含分隔符的字符串拆分可参考 MySQL——字符串拆分(含分隔符的字符串截取)

补充:mysql将查出的字符串拆分_Mysql拆分字符串查询

我就废话不多说了,大家还是直接看代码吧~

DELIMITER $$
DROP FUNCTION IF EXISTS `tms1`.`GetClassName` $$
CREATE FUNCTION `GetClassName`(f_string VARCHAR(15000)) RETURNS varchar(15000)
BEGIN
/* 判断字符串包含,的第一个位置*/
DECLARE THE_CNT INT(15) DEFAULT 1;
/* 班级编号*/
declare classId varchar(20) default '';
/* 返回的班级名称*/
DECLARE result varchar(15000) DEFAULT null;
/* 班级名称*/
DECLARE className varchar(50) DEFAULT '';
/* 字符串包含,的第一个位置*/
set THE_CNT = LOCATE(',',f_string);
/* 判断字符串包含,的第一个位置是否存在*/
while (THE_CNT >= 0) do
/* ,位置不存在的场合*/
if THE_CNT = 0 then
/* 班级编号的设置*/
set classId = f_string;
else
/* 字符串中获得班级编号*/
set classId = SUBSTRING_INDEX(SUBSTRING_INDEX(f_string, ',', 1), ',', -1);
end if ;
/* 根据班级编号获得班级名称*/
select (select name from class where id = classId) into className;
/* 返回班级编号的字符串为空的场合*/
if result is null then
/* 根据编号没有查询到班级名称的场合*/
if className is null then
/* 设置班级名称为空*/
set className = ' ';
end if;
/* 班级名称追加到字符串*/
set result = className;
else
/* 根据编号没有查询到班级名称的场合*/
if className is null then
/* 设置班级名称为空*/
set className = '  ';
end if;
/* 班级名称追加到字符串*/
set result = CONCAT(result,',',className);
end if;
/* ,位置不存在的场合*/
if THE_CNT = 0 then
/* 返回结果集*/
return result;
end if;
/* 截取传入的字符串*/
set f_string = right(f_string,length(f_string) - THE_CNT);
/* 字符串包含,的第一个位置*/
set THE_CNT = LOCATE(',',f_string);
/* 结束遍历*/
end while;
/* 返回结果集*/
return result;
END $$
DELIMITER ;

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

相关文章

  • MySQL通用查询日志和慢查询日志全面分析

    MySQL通用查询日志和慢查询日志全面分析

    这篇文章主要介绍了MySQL通用查询日志和慢查询日志的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • MySQL中字符串函数详细介绍

    MySQL中字符串函数详细介绍

    通常以串的整体作为操作对象,如:在串中查找某个子串、求取一个子串、在串的某个位置上插入一个子串以及删除一个子串等。
    2011-05-05
  • Mysql数据库中数据的操作CRUD详解

    Mysql数据库中数据的操作CRUD详解

    这篇文章主要介绍了Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括where、in、like、ifnull、与或非、order by、聚集函数等,需要的朋友可以参考下
    2025-05-05
  • Mariadb远程登陆配置及问题解决

    Mariadb远程登陆配置及问题解决

    这篇文章主要介绍了Mariadb远程登陆配置及问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • mysqladmin、mysqlshow、mysqlcheck的工具使用

    mysqladmin、mysqlshow、mysqlcheck的工具使用

    我们一般使用mysql客户端工具来进行日常的数据库操作,本文主要介绍了mysqladmin、mysqlshow、mysqlcheck的工具使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • MySQL 8.0数据字典的初始化与启动流程

    MySQL 8.0数据字典的初始化与启动流程

    数据字典(Data Dictionary, DD)用来存储数据库内部对象的信息,这些信息也被称为元数据(Metadata),包括schema名称、表结构、存储过程的定义等,本文主要介绍MySQL 8.0数据字典的基本概念和数据字典的初始化与启动加载的主要流程,需要的朋友可以参考下
    2024-06-06
  • MySQLJSON索引用法举例简单介绍

    MySQLJSON索引用法举例简单介绍

    索引是一个数据结构,索引是帮助MySQL高效获取数据的数据结构(有序),这篇文章主要给大家介绍了关于MySQLJSON索引用法的相关资料,需要的朋友可以参考下
    2024-01-01
  • 在linux服务器上配置mysql并开放3306端口的操作步骤

    在linux服务器上配置mysql并开放3306端口的操作步骤

    这篇文章主要介绍了在linux服务器上配置mysql并开放3306端口,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-09-09
  • Mysql普通索引与唯一索引的选择详析

    Mysql普通索引与唯一索引的选择详析

    这篇文章主要给大家介绍了关于Mysql普通索引与唯一索引的选择的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • mysql binlog(二进制日志)查看方法

    mysql binlog(二进制日志)查看方法

    在本篇文章里小编给大家分享了关于mysql binlog(二进制日志)查看方法,有需要的朋友们学习下。
    2019-01-01

最新评论