mysql一行逗号分割的数据分解为多行

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

在 MySQL 中,你可以使用函数 REPLACESUBSTRING_INDEX 来将一行逗号分隔的数据分解为多行。

例如,假设你有一个表,其中包含一列 items,该列包含逗号分隔的字符串,如下所示:

+----+---------------------+
| id | items               |
+----+---------------------+
| 1  | item1,item2,item3  |
| 2  | item4,item5        |
| 3  | item6              |
+----+---------------------+

你可以使用以下查询来将该表中的每一行数据分解为多行:

SELECT id,
       SUBSTRING_INDEX(SUBSTRING_INDEX(items, ',', n), ',', -1) AS item
FROM my_table,
     (SELECT @rownum := @rownum + 1 AS n
      FROM (SELECT @rownum := 0) r,
           my_table) x
WHERE n <= (LENGTH(items) - LENGTH(REPLACE(items, ',', '')) + 1);

该查询会返回如下所示的结果:

+----+-------+
| id | item  |
+----+-------+
| 1  | item1 |
| 1  | item2 |
| 1  | item3 |
| 2  | item4 |
| 2  | item5 |
| 3  | item6 |
+----+-------+

你也可以将该查询结果插入到另一个表中,以便将分解后的数据保存到数据库中。

希望这能帮助你!文章来源地址https://www.toymoban.com/news/detail-608325.html

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

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

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

相关文章

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

    有时候我们表里会存在某个字符(例如经常用到的,)分割的分割的数据,但是在使用的时候要将存在字符分割数据拆分,我们一般的做法先从数据库中将数据查询出,在内存中通过字符串分割函数split进行处理,不会在sql中通过函数进行拆分,这也符合阿里的规范,但是如果我

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

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

    2024年02月14日
    浏览(48)
  • 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日
    浏览(35)
  • mysql数据库使用sql对特殊分隔符分隔的字段进行统计

    需求 在一个数据库表中有一个字段中的数据是通过特殊符号进行分隔的,现需要统计分隔符分开的各数据的条数。 数据准备  现需统计各个绝技的人数☺ 思路 使用sql根据逗号将一行数据拆分成多行数据 ,然后使用group by对拆分的数据进行统计。 三种方式,相同的原理 使用

    2023年04月17日
    浏览(102)
  • mysql对以逗号分隔的字段内容进行查询——find_in_set函数或locate函数

    使用mysql时,有可能一个字段代表一个集合,如果将这个集合单独抽成一张表又不值当的,这个时候我们存储时,可以选择用逗号将数据分隔开(只能用英文的逗号),如图所示: 做查询时怎么查呢? 假如说给一个数据作为查询条件,判断该字段是否存在,应该怎么查呢?

    2024年02月09日
    浏览(52)
  • 将csv内容转为对象数组,它能够正确处理由逗号分隔的数据,并且能够忽略双引号中的逗号

    它能够正确处理由逗号分隔的数据,并且能够忽略双引号中的逗号。

    2024年02月12日
    浏览(42)
  • 表中签到ID格式是以逗号分隔,需将ID拆开并分成多条数据

    原有数据格式: 拆分后数据格式:    拆分SQL: select bc.资源名称,bc.资源ID,bc.签到时间,bc.签到人,bb.column_value 签到附件ID     from report_fir.V_kw_checksign_info bc,table(hbrmw6.split_string(bc.签到附件ID,\\\',\\\')) bb; HBRMW6.split_string函数创建: CREATE OR REPLACE FUNCTION HBRMW6.split_string(p_string IN VARCHAR2

    2024年02月13日
    浏览(56)
  • MYSQL: sql中某一个字段内容为用逗号分割的字符串转换成多条数据(适用于部分树机构)

    1.创建表的示例 数据如下图: SELECT a.id,SUBSTRING_INDEX(SUBSTRING_INDEX(a.userName,‘,’,b.help_topic_id+1),‘,’,-1) as name from tbl_name a left join mysql.help_topic b on b.help_topic_id (LENGTH(a.userName)-LENGTH(REPLACE(a.userName,‘,’,‘’))+1) ORDER BY a.id; 本人需求为 图层树的父级节点都在 ancestors 字段中,需要获取

    2024年02月11日
    浏览(70)
  • mysql对以逗号分隔的字段内容进行查询——find_in_set函数或locate函数或position函数

    使用mysql时,有可能一个字段代表一个集合,如果将这个集合单独抽成一张表又不值当的,这个时候我们存储时,可以选择用逗号将数据分隔开(只能用英文的逗号),如图所示: 做查询时怎么查呢? 假如说给一个数据作为查询条件,判断该字段是否存在,应该怎么查呢?

    2024年01月15日
    浏览(53)
  • Mysql 把某一列字段按照逗号分割

        该查询语句的目的是从 sys_user 表的 auth 列中将数据按逗号拆分成多行,并返回其中不重复的值。 首先,它使用子查询 (SELECT auth col FROM sys_user WHERE user_id = \\\'137\\\') AS a 来获取 sys_user 表中 user_id 为\\\'137\\\'的记录的 auth 列,并将其命名为 col 。 然后,它通过连接 mysql.help_topic 表(

    2024年02月12日
    浏览(42)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包