mysql查询逗号分割字符串(MySQL 字符串拆分实例无分隔符的字符串截取)
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 ; |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/pjymyself/article/details/81669928
- mysql慢日志查询作用(MySQL 慢查询日志的开启与配置)
- mysql要先下服务端再下客户端吗(解读MySQL的客户端和服务端协议)
- mysql基本查询方法(MySQL 重写查询语句的三种策略)
- mysql索引分几种(MySQL 覆盖索引的优点)
- MySQL配置文件my.cnf的介绍
- mysql创建数据库教程(MySQL创建数据库并支持中文字符的操作方法)
- mysql出现锁表的原因(导致MySQL做全表扫描的几种情况)
- mysql mvcc 隔离级别(详解MySQL事务的隔离级别与MVCC)
- mysql的decimal类型(MySQL数据类型DECIMAL用法详解)
- mysql权限收回(MySQL如何利用DCL管理用户和控制权限)
- 关于mysql性能优化的描述(Mysql性能优化之索引下推)
- php redis应用场景(PHP商品秒杀问题解决方案实例详解mysql与redis)
- mysql索引原理及调优(MySQL索引机制程序员必知)
- mysql提高分页效率(MySQL优化教程之超大分页查询)
- mysql百万数据分页查询优化方案(MySQL单表亿级数据分页怎么优化?)
- 如何查看mysql执行计划(到底什么是Mysql执行计划?)
- 菲律宾潜水(菲律宾潜水价格)
- 泰国人妖(变性手术生殖器要割掉吗)
- 泰国美女(泰国人妖和女性如何区分)
- 泰国旅游业怎么样(泰国的旅游产业)
- 越南新娘(越南新娘婚介网站)
- 越南新娘(越南新娘骗婚套路流程)
热门推荐
- ASP.NET全角与半角相互转换
- docker配置redis集群(基于Docker搭建Redis主从集群的实现)
- laravel关联查询限制数量(laravel-admin 后台表格筛选设置默认的查询日期方法)
- sql2012登录失败(详解安装sql2012出现错误could not open key...解决办法)
- python对mysql数据分析(python使用adbapi实现MySQL数据库的异步存储)
- vue使用elementui框架(总结Vue Element UI使用中遇到的问题)
- vue3.0路线图(Vue3.0 自己实现放大镜效果案例讲解)
- opencv 图像匹配python(OpenCV+Python识别车牌和字符分割的实现)
- linux中swap分区的作用是(linux swap交换分区详解)
- SQL Server中SET赋值和SELECT赋值
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9