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 ;

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

(0)

相关推荐

  • MySQL截取和拆分字符串函数用法示例

    本文实例讲述了MySQL截取和拆分字符串函数用法.分享给大家供大家参考,具体如下: 首先说截取字符串函数: SUBSTRING(commentid,9) 这个很简单,从第9个字符开始截取到最后.SUBSTRING的参数有三个,最后一个是截取的长度,默认是到结尾,负数是倒数第几位. 接着说拆分字符串函数: SUBSTRING_INDEX(commentid, '-', 1) 这个就稍稍复杂一些了,他的意思是以 - 进行拆分字符串,从第一个关键词开始取前面所有的字符串.如果上面的第三个参数修改为 -

  • Mysql字符串截取及获取指定字符串中的数据

    前言:本人遇到一个需求,需要在MySql的字段中截取一段字符串中的特定字符,类似于正则表达式的截取,苦于没有合适的方法,百度之后终于找到一个合适的方法:substring_index('www.sqlstudy.com.cn', '.', -2) 强烈推荐该方法获取含有特定字符的数据. substring_index(input,split,index):input为要截取的字符,split为分隔符,Index为要截取第index个分隔符左(index为正)或右(index为负)的字符串. 拿个

  • 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 需要拆分的字符串 delim 分隔符,通过某字符进行拆分 co

  • 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 为正数时

  • python如何拆分含有多种分隔符的字符串

    案例: 把某个字符串依据分隔符拆分,该字符包含不同的多种分隔符,如下 s = '12;;7.osjd;.jshdjdknx+' 其中 ; . + 是分隔符 有哪些解决方案? 方法1:通过str.split()方法,每次处理一个分隔符 #!/usr/bin/python3 def go_split(s, symbol): result = [s] for i in symbol: median = [] # 普通方法 # for x in result: # median.extend(x.spl

  • Oracle字符串拆分实例详解

    目录 Oracle字符串拆分 1. 使用regexp_substr()函数 1.1 拆分aaa,bbb,ccc 1.2 拆分aaa;bbb;ccc 1.3 level作用 2. 在oracle中实现MySQL的find_in_set()函数 2.1 使用oracle的函数定义函数FIND_IN_SET() 2.2 使用FIND_IN_SET() 2.3 删除函数FIND_IN_SET() 3. 使用存储过程输入aaa,bbb,ccc,拆分打印出来 3.1 定义存储过程 3.2 使用块执行存储过程

  • Python字符串处理实例详解

    Python字符串处理实例详解 一.拆分含有多种分隔符的字符串 1.如何拆分含有多种分隔符的字符串 问题: 我们要把某个字符串依据分隔符号拆分不同的字段,该字符串包含多种不同的分隔符,例如: s = "ab;cd|efg|hi,jkl|mn\topq;rst,uvw\txyz" 其中;,|,\t 都是分隔符号,如何处理? 方法一: 连续使用str.split()方法,每次处理一种分隔符号 s = "ab;cd|efg|hi,jkl|mn\topq;rst,uvw\txyz&q

  • MySql字符串拆分实现split功能(字段分割转列)

    目录 需求描述 实现的sql 案例演示 字符串拆分: SUBSTRING_INDEX(str, delim, count) 替换函数:replace( str, from_str, to_str) 获取字符串长度:LENGTH( str ) 实现的原理解析 扩展:判断外部值是否在 num列值中 文章参考 需求描述 数据库中 num字段值为: 实现的效果:需要将一行数据变成多行 实现的sql SELECT SUBSTRING_INDEX(SUBSTRING_INDEX('7654,7698,778

  • MySQL如何用分隔符分隔字符串

    目录 MySQL用分隔符分隔字符串 使用 效果 MySQL存储过程 根据分隔符拆分字符串 MySQL用分隔符分隔字符串 使用 可以使用如下函数 SUBSTRING_INDEX( i.final_car_type, ' ', 1 ) i.final_car_type 即 需要分隔的字符串 ’ ’ 即 用空格分隔该字符串 1 即:取出该空格之前的所有字符 也就是说,如果count是正数,那么就是从左往右数,第N个分隔符的左边的全部内容.相反,如果是负数,那么就是从右边开始数,第N个分隔符右边的所有内

  • Oracle以逗号分隔的字符串拆分为多行数据实例详解

    前言 近期在工作中遇到某表某字段是可扩展数据内容,信息以逗号分隔生成的,现需求要根据此字段数据在其它表查询相关的内容展现出来,第一想法是切割数据,以逗号作为切割符,以下为总结的实现方法,以供大家参考.指教. 1.regexp_substr函数,通过正则来拆分字符串,函数用法为:(必须是oracle 10g+的版本才支持)  REGEXP_SUBSTR函数格式如下: function REGEXP_SUBSTR(String, pattern, position, occurrence, modi

  • .NET性能优化ValueStringBuilder拼接字符串使用实例

    目录 前言 ValueStringBuilder 源码解析 适用场景 需要注意的场景 总结 前言 这一次要和大家分享的一个Tips是在字符串拼接场景使用的,我们经常会遇到有很多短小的字符串需要拼接的场景,在这种场景下及其的不推荐使用String.Concat也就是使用+=运算符.目前来说官方最推荐的方案就是使用StringBuilder来构建这些字符串,那么有什么更快内存占用更低的方式吗?那就是今天要和大家介绍的ValueStringBuilder. ValueStringBuilder Val

  • js获取指定字符前/后的字符串简单实例

    如下所示: <!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> </head> <script type="text/javascript"> /* string 字符串; str 指定字符; split(),用于把一个字符串分割成字符串数组; split(str)[0],读取

随机推荐