mysql字符串拆成多列_sql分割: 把字符串分割成多列
现有如下需求:需要将字符串
1,2,3,4,5,6,7
拆分成:
1
2
3
4
5
6
7
分析:
为了完成上述功能,在mysql中提供了一些字符串操作的函数,其中SUBSTRING_INDEX(str, delim, count)
str: 要处理的字符串
delim: 分割符
count: 计数 如果为正数,则从左开始数,如果为负数,则从右开始数
例:
str = 'www.baidu.com';
SELECT substring_index('www.baidu.com','.', 1); #www
SELECT substring_index('www.baidu.com','.', 2); #www.baidu
SELECT substring_index('www.baidu.com','.', -1); #com
SELECT substring_index('www.baidu.com','.', -2); #baidu.com
SELECT substring_index(substring_index('www.baidu.com','.', -2), '.', 1); #baidu
有了这个函数的帮助,我们还需要确定什么呢?
需要知道 当前要分割的位置
如何来获取当前要分割的位置呢?
我们可以先获取总共能拆分成多少个字符串
SELECT LENGTH('1,2,3,4,5,6,7') - LENGTH(REPLACE('1,2,3,4,5,6,7', ',', '')) + 1;
结果为7,那么其实我们想要的就是遍历1到6,分别获取当前位置的字符串:
SELECT substring_index(substring_index('1,2,3,4,5,6,7',',', index), ',', -1)
其中index就是我们要遍历的位置,所以为了遍历,我们需要一个关联一个辅助表来得到当前位置,最后的设计
如下:
SELECT substring_index(substring_index(t.context,',', b.help_topic_id + 1), ',', -1) FROM test.test t join mysql.help_topic b ON b.help_topic_id < (LENGTH(t.context) - LENGTH(REPLACE(t.context, ',', '')) + 1);
其中表test数据如下:
id
context
2
1,2,3,4,5,6,7
这里使用到mysql的内置表help_topic_id,里面有508条数据(不同版本数据条数有差别),用户需要有对该表查询的权限才行,这样的话只满足分割数量少于508条的字符串,否则应该自定义辅助表,设置更大的一个递增列
mysql字符串拆成多列_sql分割: 把字符串分割成多列相关推荐
- mysql sql数值转字符拼接_sql中的字符串拼接
1. 概述 在SQL语句中经常需要进行字符串拼接,以sqlserver,oracle,mysql三种数据库为例,因为这三种数据库具有代表性. sqlserver: select '123'+'456' ...
- php如何把字符串拆成一个一个的,php 将一个字符串分割为组成它的字符
问: php里如何将一个字符串分割为组成它的字符? 比如hello -> [h, e, l, l, o] 以下有三种方法: 这是需要被分割的字符串: $str = 'Hello小样'; ...
- mysql字段分隔符拆分_MySQL里实现类似SPLIT的分割字符串的函数
下边的函数,实现了象数组一样去处理字符串. 一,用临时表作为数组 复制代码 代码如下: create function f_split(@c varchar(2000),@split varchar( ...
- PHP根据逗号分割,将字符串转成数组
PHP根据逗号分割,将字符串转成数组 <?php$str = '电气鼠,蒹葭苍苍,小飞鱼,奶片';// 根据逗号分割,将字符串转成数组$array = explode(',', $str);ec ...
- MySQL的行转列、列转行、连接字符串 concat、concat_ws、group_concat函数用法
转载自:https://blog.csdn.net/aya19880214/article/details/41280893 1.concat函数 使用方法: CONCAT(str1,str2,-) ...
- mysql select 返回列_SQL / mysql – selectdistinct / UNIQUE,但返回所有列?
你正在寻找一个组: select * from table group by field1 偶尔可以写一个独特的声明: select distinct on field1 * from table 然 ...
- mysql sql 字符串字段保留数字_sql中取字符串中的数字语句_MySQL
bitsCN.com one: declare @s varchar(20) declare @i varchar(20) set @i='' set @s='新会员必须购买350元产品' while ...
- 实际开发问题解决记录: 需求是mysql执行查询 返回数据给前端 既要返回值不为NULL的列也要返回值为NULL的列(值为NULL的列列名返回给前端)
一.查询值不为NULL 的列 我们先来看数据库所有数据 执行的sql语句: select id,FCJ,comeCoalForecast from FCJ 查询结果如下: 看完执行查询所有数据的例子 ...
- 合并列值(将一列的多个值合并成一行)
目录 需求 效果 sql语法 需求 将一列的多个值合并成一行并用逗号分割 效果 sql语法 mysql写法: --默认的逗号分隔 select GROUP_CONCAT(A.title) as cit ...
- 数据分析--积累--presto--一列转多行--数组分割展开
我们在做数据分析时,有时候需要使用join等作表连接,或者说 通过一些数据作关联. 但是 如果需要的数据 是存储的一列中使用逗号分割,或者存储在数组中,就不能很方便的进行表连接. presto提供了很 ...
最新文章
- wxWidgets利用透明图片自定义工具条
- Objective-C 运行AppleScript脚本
- winform combobox选择后_后驱车真的比前驱车更加高级吗?涨知识了!
- day32 管道, 数据共享, 进程池, 回调函数
- Flask-认识flask
- Linux: Shared MIME
- Some personal records
- 【Linux】Linux JSON 格式化输出
- loadrunner11使用谷歌代理录制脚本全过程
- [样本分析] Ramnit感染型病毒
- ABAP新手基础入门知识
- Linux桌面系统远程访问全解析
- Mac 安装svn客户端+idea配置svn
- 获取shell文件路径方法
- 知乎9.6万赞热帖:“为什么飞机的头等舱一直拉着帘子?”答案细思极恐
- 只需5步,从0开始搭建你的第一款小程序
- 模拟机械键盘音效的软件
- [C++程序设计](入门级题解)小鱼的航程
- 机器视觉——光源选型原理及使用方法
- 华为H3C 交换机路由器常用命令