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 ;
以上为个人经验,希望能给大家一个参考,也希望大家多多支持猪先飞。如有错误或未考虑完全的地方,望不吝赐教。
相关文章
- 这篇文章主要介绍了C#中截取字符串的的基本方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-03
- 这篇文章主要介绍了MySQL性能监控软件Nagios的安装及配置教程,这里以CentOS操作系统为环境进行演示,需要的朋友可以参考下...2015-12-14
- 这篇文章介绍了C#判断字符串是否数字或字母的实例,有需要的朋友可以参考一下...2020-06-25
- 这篇文章主要介绍了PostgreSQL判断字符串是否包含目标字符串的多种方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-02-23
- 这篇文章主要介绍了C++ string常用截取字符串方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-25
- 新版 Mysql 中加入了对 JSON Document 的支持,可以创建 JSON 类型的字段,并有一套函数支持对JSON的查询、修改等操作,下面就实际体验一下...2016-08-23
- 本文实例讲述了php字符串按照单词进行反转的方法。分享给大家供大家参考。具体分析如下:下面的php代码可以将字符串按照单词进行反转输出,实际上是现将字符串按照空格分隔到数组,然后对数组进行反转输出。...2015-03-15
- 整数拆分,指把一个整数分解成若干个整数的和。本文重点给大家介绍C++ 整数拆分方法详解,非常不错,感兴趣的朋友一起学习吧...2020-04-25
深入研究mysql中的varchar和limit(容易被忽略的知识)
为什么标题要起这个名字呢?commen sence指的是那些大家都应该知道的事情,但往往大家又会会略这些东西,或者对这些东西一知半解,今天我总结下自己在mysql中遇到的一些commen sense类型的问题。 ...2015-03-15- 这篇文章主要介绍了使用list stream:任意对象List拼接字符串操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-09
- 这篇文章主要介绍了MySQL 字符串拆分操作(含分隔符的字符串截取),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-22
- 这篇文章主要介绍了C# 16 进制字符串转 int的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下...2020-06-25
- JS中默认中文字符长度和其它字符长度计算方法是一样的,但某些情况下我们需要获取中文字符串的实际长度,代码如下: 复制代码 代码如下: function strLength(str) { var realLength = 0, len = str.length, charCode = -1;...2014-06-07
- 一、先说一下为什么要分表:当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,有可能会死在那儿了。分表的目的就在于此,减小数据库的负担,缩短查询时间。根据个人经验,mysql执行一个sql的过程如下:1...2014-05-31
- 这篇文章主要介绍了C#实现字符串转换成字节数组的简单实现方法,仅一行代码即可搞定,非常简单实用,需要的朋友可以参考下...2020-06-25
- 文章介绍一个实用的函数,我们如果用php substr来截取字符在中文上处理的很有问题,今天自己写了一个比较好的中文与英文字符截取的函数,有需要的朋友可以参考下。 ...2016-11-25
- 这篇文章主要介绍了C#实现对字符串进行大小写切换的方法,涉及C#操作字符串的技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- 我们自己鼓捣mysql时,总免不了会遇到这个问题:插入中文字符出现乱码,虽然这是运维先给配好的环境,但是在自己机子上玩的时候咧,总得知道个一二吧,不然以后如何优雅的吹牛B。...2015-03-15
- 这篇文章主要介绍了c#将字节数组转成易读的字符串的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-06-25
- 这篇文章主要介绍了PostgreSQL 字符串处理与日期处理操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-02-01