现有如下需求:需要将字符串

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分割: 把字符串分割成多列相关推荐

  1. mysql sql数值转字符拼接_sql中的字符串拼接

    1. 概述 在SQL语句中经常需要进行字符串拼接,以sqlserver,oracle,mysql三种数据库为例,因为这三种数据库具有代表性. sqlserver: select '123'+'456' ...

  2. php如何把字符串拆成一个一个的,php 将一个字符串分割为组成它的字符

    问: php里如何将一个字符串分割为组成它的字符? 比如hello  -> [h, e, l, l, o]   以下有三种方法: 这是需要被分割的字符串:  $str = 'Hello小样'; ...

  3. mysql字段分隔符拆分_MySQL里实现类似SPLIT的分割字符串的函数

    下边的函数,实现了象数组一样去处理字符串. 一,用临时表作为数组 复制代码 代码如下: create function f_split(@c varchar(2000),@split varchar( ...

  4. PHP根据逗号分割,将字符串转成数组

    PHP根据逗号分割,将字符串转成数组 <?php$str = '电气鼠,蒹葭苍苍,小飞鱼,奶片';// 根据逗号分割,将字符串转成数组$array = explode(',', $str);ec ...

  5. MySQL的行转列、列转行、连接字符串 concat、concat_ws、group_concat函数用法

    转载自:https://blog.csdn.net/aya19880214/article/details/41280893 1.concat函数 使用方法: CONCAT(str1,str2,-) ...

  6. mysql select 返回列_SQL / mysql – selectdistinct / UNIQUE,但返回所有列?

    你正在寻找一个组: select * from table group by field1 偶尔可以写一个独特的声明: select distinct on field1 * from table 然 ...

  7. mysql sql 字符串字段保留数字_sql中取字符串中的数字语句_MySQL

    bitsCN.com one: declare @s varchar(20) declare @i varchar(20) set @i='' set @s='新会员必须购买350元产品' while ...

  8. 实际开发问题解决记录: 需求是mysql执行查询 返回数据给前端 既要返回值不为NULL的列也要返回值为NULL的列(值为NULL的列列名返回给前端)

    一.查询值不为NULL 的列 我们先来看数据库所有数据 执行的sql语句:  select id,FCJ,comeCoalForecast from FCJ 查询结果如下: 看完执行查询所有数据的例子 ...

  9. 合并列值(将一列的多个值合并成一行)

    目录 需求 效果 sql语法 需求 将一列的多个值合并成一行并用逗号分割 效果 sql语法 mysql写法: --默认的逗号分隔 select GROUP_CONCAT(A.title) as cit ...

  10. 数据分析--积累--presto--一列转多行--数组分割展开

    我们在做数据分析时,有时候需要使用join等作表连接,或者说 通过一些数据作关联. 但是 如果需要的数据 是存储的一列中使用逗号分割,或者存储在数组中,就不能很方便的进行表连接. presto提供了很 ...

最新文章

  1. wxWidgets利用透明图片自定义工具条
  2. Objective-C 运行AppleScript脚本
  3. winform combobox选择后_后驱车真的比前驱车更加高级吗?涨知识了!
  4. day32 管道, 数据共享, 进程池, 回调函数
  5. Flask-认识flask
  6. Linux: Shared MIME
  7. Some personal records
  8. 【Linux】Linux JSON 格式化输出
  9. loadrunner11使用谷歌代理录制脚本全过程
  10. [样本分析] Ramnit感染型病毒
  11. ABAP新手基础入门知识
  12. Linux桌面系统远程访问全解析
  13. Mac 安装svn客户端+idea配置svn
  14. 获取shell文件路径方法
  15. 知乎9.6万赞热帖:“为什么飞机的头等舱一直拉着帘子?”答案细思极恐
  16. 只需5步,从0开始搭建你的第一款小程序
  17. 模拟机械键盘音效的软件
  18. [C++程序设计](入门级题解)小鱼的航程
  19. 机器视觉——光源选型原理及使用方法
  20. 华为H3C 交换机路由器常用命令

热门文章

  1. eMMC5.1和UFS2.1 区别
  2. 身体质量指数(BMI)测算
  3. 直接用笔记本摄像头跑orb_slam3单目程序 不再跑数据集
  4. 【Java】Properties类
  5. LintCode领扣算法问题答案:501. 迷你推特
  6. 腾讯云“金融分布式核心”联合解决方案
  7. 旅游行业会员营销制胜关键:培育客户忠诚度
  8. micropython plc_基于PLC的模拟I/O系统的实现
  9. MySQL数据库迁移方案比较和使用
  10. 【2023-03-10】JS逆向之美团滑块