Mysql 以字符分割一行变多行(substring_index函数)

这篇具有很好参考价值的文章主要介绍了Mysql 以字符分割一行变多行(substring_index函数)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

问题

有时候我们表里会存在某个字符(例如经常用到的,)分割的分割的数据,但是在使用的时候要将存在字符分割数据拆分,我们一般的做法先从数据库中将数据查询出,在内存中通过字符串分割函数split进行处理,不会在sql中通过函数进行拆分,这也符合阿里的规范,但是如果我们是出报表,通过其他平台写sql的方式进行拆分展示,不经过内存字符串分割,这时候我们只能通过sql 函数substring_index来处理,下面介绍2种方式

解决方案

创建表

create table tb_staff_position_info
(
    id                 varchar(255)                           not null comment '主键'
        primary key,
    created_at         timestamp    default CURRENT_TIMESTAMP not null comment '记录创建时间',
    updated_at         timestamp    default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP comment '记录修改时间',
   staff_name    varchar(64)  default ''                not null comment '员工名称',
   position_name    varchar(64)  default ''                not null comment '多个职位以,号分割',
  
)
    comment '员工职位表' charset = utf8;

初始化数据

insert into tb_staff_position_info(staff_name,position_name)values
('小平','技术组长,产品经理,项目经理'),('小花','程序员,测试员,'),('小广‘,'研发总监')

预期查询

查询员工所属的职位,多个职位显示多行

整体思路

1、将position_name 以","号进行拆分,使用mysql 的substring_index(clunm,拆分字符,第几个n) 函数,substring_index函数每次只能获取一个职位

2、借助临时表,从0开始自增,数据中最多有多少个分割字符,临时表就有多少条数据

方案一

借助mysql 的自增表,如下

select 
  info.staff_name,
  substring_index(
        substring_index(
            info.position_name ,
            ',',
            b.n + 1
        ),
        ',' ,- 1
    ) AS position_name
  from tb_staff_position_info info
  join mysql.help_topic b  
on b.help_topic_id < ( length(info.position_name ) - length(REPLACE (info.position_name , ',', ''))  + 1 ) 

临时表借助于mysql的help_topic 表中的 help_topic_id来实现

方案二

有时候查询用户的权限无法访问mysql的表,那么我们也可以创建一个临时表替换,如下所示

select 
  info.staff_name,
  substring_index(
        substring_index(
            info.position_name ,
            ',',
            b.n + 1
        ),
        ',' ,- 1
    ) AS position_name
  from tb_staff_position_info info
  join (
          select 0 as n
          union all 
          select 1 as n
          union all 
          select 2 as n
          ) b 
         on b.n < ( length(info.position_name ) - length(REPLACE (info.position_name , ',', ''))  + 1 )

上述创建的临时表b 最多能匹配 3个分割符,如果存在大于3个那么在将数据插入到临时表即可

方案三

临时表变成正式表,在数据库中创建一张自增表

总结

上述方式各有千秋,下面总结优缺点

优缺点

方法一:

优点:临时表借助mysql 内置的help_topic 表,无需自己创建临时表

缺点:存在查询账号权限的限制,有的账号是无法访问mysql内置表

方法二:

优点:创建自增的临时表不存在权限的限制

缺点:如果分割符存在多个,就要插入多条数据,写法上没有方法一整洁优雅文章来源地址https://www.toymoban.com/news/detail-777265.html

到了这里,关于Mysql 以字符分割一行变多行(substring_index函数)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SQL32 截取出年龄(substring_index函数的用法)

    substring_index(FIELD, sep, n)可以将字段FIELD按照sep分隔: (1).当n大于0时取第n个分隔符(n从1开始)之前的全部内容; (2).当n小于0时取倒数第n个分隔符(n从-1开始)之后的全部内容;

    2024年02月22日
    浏览(25)
  • mysql一行逗号分割的数据分解为多行

    在 MySQL 中,你可以使用函数 REPLACE 和 SUBSTRING_INDEX 来将一行逗号分隔的数据分解为多行。 例如,假设你有一个表,其中包含一列 items ,该列包含逗号分隔的字符串,如下所示: 你可以使用以下查询来将该表中的每一行数据分解为多行: 该查询会返回如下所示的结果: 你也

    2024年02月15日
    浏览(29)
  • 【问题解决】mysql 数据库字符串分割之后多行输出方法

    项目需要从一张表查询出来数据插入到另一张表,其中有一个字段是用逗号分隔的字符串,需要多行输入到另一张表,那么这个如何实现呢 下面先粘贴下sql语句: 参数解释 1.SUBSTRING_INDEX(str, delimiter, count)     参数解释     str :必填。STRING类型。待截取的字符串     separat

    2024年02月14日
    浏览(37)
  • mysql中将多行数据合并成一行数据

    mysql中将多行数据合并成一行数据 一个字段可能对应多条数据,用mysql实现将多行数据合并成一行数据 例如:一个活动id(activeId)对应多个模块名(modelName),按照一般的sql语句: SELECT am.activeId,m.modelName FROM activemodel am JOIN model m ON am.modelId = m.modelId ORDER BY am.activeId 查询出的列

    2024年02月16日
    浏览(25)
  • MySQL将以逗号分隔的数据分成多行,再合并为一行

    最近遇到个这样的问题,MySQL中的【影片表】中 [演员列] 的内容是用逗号分隔的多个id存储的(例:4356,9691,11337),然后需要把他换成id对应的演员名字(例:屈菁菁,王太利,肖央) 看起来很复杂,其实只要把问题拆分一下就会非常简单 分为三步 第一步:把逗号分隔的多个

    2024年02月11日
    浏览(31)
  • mysql根据逗号将一行数据拆分成多行数据,顺便展示其他列

    2.处理结果  SQL展示 这个join最基本原理是笛卡尔积。通过这个方式来实现循环。 分析: length(a.path) - length(replace(a.path,‘,’,‘’))+1 表示了,按照逗号分割后,分割需要循环的次数。 join过程: 根据ID进行循环 { 判断:i 是否 = n 获取最靠近第 i 个逗号之前的数据, 即 substr

    2024年02月09日
    浏览(33)
  • 主流数据库(SQL Server、Mysql、Oracle)通过sql实现多行数据合为一行

    1、方法一:使用 STUFF 和 FOR XML PATH 进行多行合并成一行 (1)FOR XML PATH用法 FOR XML 是 SQL Server 提供的一种功能,允许您将查询结果转换为 XML 格式。 PATH 模式则是其中一种灵活的方式来构造自定义的XML结构。 1、基本字符串连接 : 当您想从单列中提取所有行的数据并连接成一

    2024年04月10日
    浏览(45)
  • 【MySQL】字符串截取函数 SUBSTR() 详解

    从指定位置开始的输入字符串返回一个子字符串。 SUBSTR() 函数的常用方法如下。 其中 字符串 可以是具体的字符串内容也可以是数据库的字段,或者字符串运算之后的内容。 起点和长度要求是整数,其中长度必须大于0。 1.返回起点之后的子字符串 2.返回从字符串末尾的第

    2024年02月10日
    浏览(49)
  • SQL的substring函数及其用法实例——MYSQL另一种截取目标字符的函数

    目录 1.substring()的语法和用法实例 (1)两个参数的语法和用法实例 ①语法:substring(string ,index)|substring(string from index) ②用法实例: 从指定字符串的某序数开始获取字符 (2)三个参数的语法和用法实例 ①语法:substring(string ,index,len)|substring(string from index for len) ②用法实

    2023年04月08日
    浏览(30)
  • flex布局一行三个,显示多行

    效果: 代码

    2024年02月11日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包