我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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 ;

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

无分隔符的字符串截取 题目要求 数据库中字段值:实现效果:需要将一行数据变成多行实现的sqlSELECT LEFT(SUBSTRING('P1111',help_topic_id+1),1) AS num FROM mysql.help_t
2022-05-30

MySQL 字符串拆分操作(含分隔符的字符串截取)

无分隔符的字符串截取 题目要求 数据库中字段值:实现效果:需要将一行数据变成多行实现的sqlSELECT LEFT(SUBSTRING('P1111',help_topic_id+1),1) AS num FROM mysql.help_t
2022-05-22

Mysql - 字符串截取、拆分

前言 在开发过程中,字符串的截取虽然可以在程序代码中来做,但是如果可以在 SQL 语句中处理,又不会造成 SQL 语句变的很复杂,那自然就可以在 SQL 语句中处理,速度还会更快一点。这个就需要根据具体的业务进行衡量了 概述 一、截取字符串
2023-08-19

Python中拆分具有多个分隔符的字符串方法实例

str.split()是Python中字符串类型的一个方法,可以用来将字符串按照指定的分隔符分割成多个子字符串,这篇文章主要给大家介绍了关于Python中拆分具有多个分隔符的字符串的相关资料,需要的朋友可以参考下
2023-05-18

mysql 字符串拆分并分组

这篇文章主要为大家详细介绍了mysql 字符串拆分并分组,文中示例代码介绍的非常详细,具有一定的参考价值,发现的小伙伴们可以参考一下:无分隔符的字符串截取题目要求数据库中字段值:实现效果:需要将一行数据变成多行实现的sqlSELECT LE
2023-06-06

【Kotlin】字符串操作 ① ( 截取字符串函数 substring | 拆分字符串函数 split | 解构语法特性 )

文章目录 一、截取字符串函数 substring二、拆分字符串函数 split 一、截取字符串函数 substring Kotlin 中提供了 截取字符串函数 substring , 可接收 IntRange 类型
2023-08-19

Oracle字符串拆分实例详解

目录oracle字符串拆分1. 使用regexp_substr()函数1.1 拆分aaa,bbb,ccc1.2 拆分aaa;bbb;ccc1.3 level作用2. 在oracle中实现mysql的find_in_set()函数2.1 使用
2023-04-03

浅谈Java字符串的截取和分割、比较字符串

这篇文章我们浅谈Java字符串的截取和分割、比较字符串和switch语句支持字符串类型知识。

sqlserver实现分隔字符串

sqlserver 使用函数实现分隔字符串create function dbo.fn_split( @str_source nvarchar(max), @split_char nvarchar(100))returns @temp table(
2019-08-31

python spilt()分隔字符串的实现示例

1 spilt() 方法作用 通过指定分隔符对字符串进行分隔 注意要拆分的字符串需要要一定规律的分隔符 ,比如"Python is a good language" 这个字符串中间都有个空格,那么我们可以通过这个空格来分隔这个字符串 2
2022-06-02

编程热搜

目录