mysql根据指定字符拆分某个字段,并将数据分割成多条记录

mysql根据指定字符拆分某个字段,并将数据分割成多条记录

表名 t_course_comment
表数据
在这里插入图片描述

拆分字段 studentids
mysql语句:

select distinct
a.id,
a.teacherid,
a.courseid,
a.course_type,
a.course_time,
a.course_hours,
substring_index (substring_index (a.studentids,’,’,b.help_topic_id + 1),’,’,- 1) studentid
from
t_course_comment a
join mysql.help_topic b
on b.help_topic_id < ( length (a.studentids) - length(replace(a.studentids,’,’,’’))+1)
where a.id = 1
注释:替换加粗字段即可
注意:复制后可能会因为这八个符号问题报错,记得更改
在这里插入图片描述
下面为代码片区直接复制即可,不会出现符号问题

SELECT DISTINCT
a.id,
a.teacherid,
a.courseid,
a.course_type,
a.course_time,
a.course_hours,
SUBSTRING_INDEX (SUBSTRING_INDEX (a.studentids,',',b.help_topic_id + 1),',',- 1) studentid
FROM
t_course_comment a
JOIN mysql.help_topic b
ON b.help_topic_id < ( LENGTH (a.studentids) - LENGTH(REPLACE(a.studentids,',',''))+1)
WHERE a.id = 1

查询结果
在这里插入图片描述

所用函数:

  1. substring_index 拆分函数
    substring_index(str,delim,count)
    str:要处理的字符串
    delim:分隔符
    count:计数
  2. mysql.help_topic 默认自增序列表
  3. distinct 去重复函数
  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值