http://blog.csdn.net/mchdba/article/details/53889803

-------------------------------------------------------------------------------

  1. mysql> create table t1(c1 varchar(32),c2 varchar(32));
  2. Query OK, 0 rows affected (0.02 sec)
  3. mysql> INSERT INTO t1 SELECT 'man' c1,'123,234,567,789' c2 UNION ALL SELECT 'guo','-12,-87,-09,132' UNION ALL SELECT 'fang','1024,2387,1209,1032';
  4. Query OK, 3 rows affected (0.02 sec)
  5. Records: 3  Duplicates: 0  Warnings: 0
  6. mysql> select * from t1;
  7. +------+---------------------+
  8. | c1   | c2                  |
  9. +------+---------------------+
  10. | man  | 123,234,567,789     |
  11. | guo  | -12,-87,-09,132     |
  12. | fang | 1024,2387,1209,1032 |
  13. +------+---------------------+
  14. 3 rows in set (0.00 sec)
  15. mysql>

需要达到的效果是,左边变成右边,按照逗号拆分出来,单列变成多行记录,而且保留原来的其它列数据,如下图所示:

#,blog原地址:http://blog.csdn.net/mchdba/article/details/53889803,作者mchdba,谢绝转载

这个复杂的实现,单条的sql或者几条sql无法达到,需要临时表存储中间数据,所以编写存储过程,间接实现,存储过程如下:

  1. DELIMITER $$
  2. USE `test`$$
  3. DROP PROCEDURE IF EXISTS `proc_cur_split_str`$$
  4. USE `test`$$
  5. CREATE PROCEDURE test.proc_cur_split_str()
  6. BEGIN
  7. DECLARE v_c1 VARCHAR(20);
  8. DECLARE v_c2 VARCHAR(60);
  9. DECLARE _done INT DEFAULT 0;
  10. DECLARE cur_strs CURSOR FOR SELECT c1,c2 from test.t1 ;
  11. DECLARE CONTINUE HANDLER FOR NOT FOUND BEGIN SET _done=1; END;
  12. DROP TABLE IF EXISTS test.ZZ_2;
  13. CREATE TABLE test.ZZ_2(C1 VARCHAR(20),CN VARCHAR(60));
  14. OPEN cur_strs;
  15. FETCH cur_strs INTO v_c1, v_c2;
  16. WHILE _done != 1  DO
  17. DROP TABLE IF EXISTS test.ZZ_1;
  18. CREATE TABLE ZZ_1(CN VARCHAR(60));
  19. SET @b=v_c2;
  20. SET @a = CONCAT(CONCAT("insert into test.ZZ_1 values('",REPLACE(@b,',',"'),('")),"')");
  21. -- SELECT @a;
  22. PREPARE stmt1 FROM @a;
  23. EXECUTE stmt1;
  24. -- SELECT v_c1,t.* FROM test.ZZ_1 t;
  25. INSERT INTO ZZ_2 SELECT v_c1,t.* FROM test.ZZ_1 t;
  26. COMMIT;
  27. -- SELECT * FROM test.ZZ_2;
  28. FETCH cur_strs INTO v_c1, v_c2;
  29. END WHILE;
  30. CLOSE cur_strs;
  31. SELECT * FROM test.ZZ_2;
  32. END;
 

执行存储过程,得到执行结果,符合心理预期,单列C1变成多行,并且保留了原来的其它字段c1的数据值,如下所示,

MySQL 5.7.16 字符串拆分 -> 单列变多行记录(转发)的更多相关文章

  1. Excel技巧--单列变多行

    当上图的单列转变成多行时,可以这么做: 1.在第一行输入A2.A3,向右拖拉第一行: 2.第二行按第一行最右顺序,写下A12,再向右拖拉出第二行: 3.选择这两行,再拖拉出一串连续顺序的多行来: 4. ...

  2. 【SQL】sql版Split函数。用于拆分字符串为单列表格

    功能与.net版string.Split函数类似,只不过.net返回的是数组,这个返回的是一个单列表格,每个拆分出来的子串占一行.可选是否移除空格子串和重复项.市面上类似的函数不算少,但大多都是在循环 ...

  3. 2016/4/5 Ajax ①用户名 密码 登陆 注册 ② 判断用户名是否已存在 ③点击按钮出现民族选项下拉菜单 ④DBDA类 加入Ajaxquery方法 数组变字符串 字符串拆分

    ①登陆   注册    查表匹配    0405Ajax.php   ②判断用户名是否存在 <!DOCTYPE html> <html lang="en"> ...

  4. mysql字符串拆分实现split功能

    转自:https://blog.csdn.net/pjymyself/article/details/81668157有分隔符的字符串拆分题目要求数据库中 num字段值为: 实现的效果:需要将一行数据 ...

  5. Mysql 字符串拆分 OR 一行转多行

    Mysql 字符串拆分 OR 一行转多行 需要了解的的几个mysql 函数: A.substring_index():字符串截取 substring_index(str,delim,count)   ...

  6. UTF-8编码的字符串拆分成单字、获取UTF-8字符串的字符个数的代码及原理

    一.字符编码简介 1. ASCII码 在计算机内部,所有的信息最终都表示为一个二进制的字符串.每一个二进制位(bit)有0和1两种状态,因此八个二进制位就可以组合出256种状态,这被称为一个字节(by ...

  7. mycat1.6.5分片(字符串拆分hash)

    https://blog.csdn.net/webnum/article/details/78313525   分片规则:字符串拆分hash 一.conf/schema.xml文件   <?xm ...

  8. SQL2000/2005字符串拆分为列表通用函数

    ------------------------------------------------------------------ --  Author : htl258(Tony) --  Dat ...

  9. mysql根据字符截取字符串(总结)

    mysql根据字符截取字符串(总结) 1.1 前言   为结合自己平常查资料的习惯,我会先给出例子,然后再对相关知识进行详解.该案例使用到的函数为:SUBSTRING_INDEX 1.2 需要实现的实 ...

随机推荐

  1. socket 映射服务器程序

    server #include <stdio.h> #include <sys/types.h> /* See NOTES */ #include <sys/socket ...

  2. NOI-1.1-04输出保留3位小数的浮点数

    04:输出保留3位小数的浮点数 总时间限制:  1000ms 内存限制:  65536kB 描述 读入一个单精度浮点数,保留3位小数输出这个浮点数. 输入 只有一行,一个单精度浮点数. 输出 也只有一 ...

  3. [LeetCode&Python] Problem 389. Find the Difference

    Given two strings s and t which consist of only lowercase letters. String t is generated by random s ...

  4. Android强制横屏+全屏的几种常用方法

    全屏: 在Activity的onCreate方法中的setContentView(myview)调用之前添加下面代码 1 requestWindowFeature(Window.FEATURE_NO_ ...

  5. xdoj1321----简单搜索

    1321: 营救公主 时间限制: 1 Sec  内存限制: 128 MB提交: 156  解决: 37[提交][状态][讨论版] 题目描述 DSKer今天又做梦了,他的睡眠质量一直很差.他梦见他化身骑 ...

  6. P1220 关路灯 (区间dp)

    题目链接:传送门 题目大意: 总共有N盏灯,老张从点C(1 ≤ C ≤ N)开始关灯(关灯不需要等待时间,C点的灯直接关掉),与此同时灯开始烧电(已知功率Pi). 老张每次可以往左走关最近的灯或者往右 ...

  7. HDU2021发工资咯:)

    Problem Description 作为杭电的老师,最盼望的日子就是每月的8号了,因为这一天是发工资的日子,养家糊口就靠它了,呵呵 但是对于学校财务处的工作人员来说,这一天则是很忙碌的一天,财务处 ...

  8. PHP黑魔法(该篇文章转自:http://www.91ri.org/12634.html 目的是作为自己的笔记方便查找)

    那些年我们学过的PHP黑魔法 作者:Matrix_ling 序 这里必须得说一下==和===这俩货的重要性.==是比较运算,它不会去检查条件式的表达式的类型===是恒等,它会检查查表达式的值与类型是否 ...

  9. 实验吧—Web——WP之 上传绕过

    我们先上传一个png文件,发现他说必须上传后缀名为PHP的文件才可以,那么,我们尝试一下,PHP文件 但是他又说不被允许的文件类型 在上传绕过里最有名的的就是00截断,那么我们就先要抓包 在这里我们需 ...

  10. python------模块定义、导入、优化 ------->xml模块

    1. xml模块 引用参考原文链接:https://www.cnblogs.com/python-gm/p/8032465.html      谢谢 xml是实现不同语言或程序之间进行数据交换的协议, ...