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

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

Scroll Down

无分隔符的字符串截取

题目要求

数据库中字段值:

MySQL字符串拆分1.png

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

MySQL字符串拆分2.png

实现的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)

参数说明

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

举例

从第2个字符开始获取字符串’P1111’

SUBSTRING('P1111',2)

MySQL字符串拆分3.png

从倒数第2个字符开始获取字符串’P1111’

SUBSTRING('P1111',-2)

MySQL字符串拆分4.png

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

参数说明

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

举例

获取字符串’P1111’最左边的3个字符

LEFT('P1111',3)

MySQL字符串拆分5.png

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字符串拆分6.png

————————————————
版权声明:本文为CSDN博主「pjymyself」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/pjymyself/article/details/81669928