时间:2021-05-23
题目要求
数据库中字段值:
实现效果:需要将一行数据变成多行
实现的sql
SELECT LEFT(SUBSTRING('P1111',help_topic_id+1),1) AS num FROM mysql.help_topic WHERE help_topic_id < LENGTH('P1111');1、参数说明
参数名 解释 str 被截取的字符串 pos 从第几位开始截取,当 pos 为正数时,表示从字符串开始第 pos 位开始取,直到结束;当pos为负数时,表示从字符串倒数第 pos位开始取,直到结束。2、 举例
(一)从第2个字符开始获取字符串'P1111'
SUBSTRING('P1111',2)(二)从倒数第2个字符开始获取字符串'P1111'
SUBSTRING('P1111',-2)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)BEGINDECLARE 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) doif THE_CNT = 0 thenset classId = f_string;elseset 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 thenif className is null thenset className = ' ';end if;set result = className;elseif className is null thenset className = ' ';end if;set result = CONCAT(result,',',className);end if;if THE_CNT = 0 thenreturn 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 ;以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、如何拆分含有多种分隔符的字符串?实际案例我们要把某个字符串依据分隔符号拆分不同的字符段,该字符串包含多种不同的分隔符,例如:s='asd;aad|dasd|
本文实例讲述了Python针对任意多的分隔符拆分字符串操作。分享给大家供大家参考,具体如下:问题:将分隔符(以及分隔符之间的空格)不一致的字符串拆分为不同的字段
C#中有一个字符串拆分函数String.Split(),可以用于将一个字符串,拆分为一个字符串数组。在拆分的时候,需要一个拆分的“分隔符”。这个“分隔符”可以是
使用字符串时,常见的操作之一是使用给定的分隔符将字符串拆分为子字符串数组。在本文中,我们将讨论如何在Python中拆分字符串。.split()方法在Python
函数:split()Python中有split()和os.path.split()两个函数,具体作用如下:split():拆分字符串。通过指定分隔符对字符串进行