转载

MySQL列转行巧录数据

开发同学让我帮忙看看一个数据怎么录合适。
原始的数据如下,要录入到数据库里。
MySQL列转行巧录数据

先取消Excel的单元格合并.
MySQL列转行巧录数据

删除第一行和第二行的数据,这些都是标题.
然后导出CSV文件,
使用文本文件编辑器打开CSV,替换 - 为 ,
MySQL列转行巧录数据

然后 德塔贝斯 建个表。
再将CSV数据导入.

  1. create table t(
  2.     id int primary key auto_increment,
  3.     starttime time,
  4.     endtime time,
  5.     d1 varchar(20),
  6.     d2 varchar(20),
  7.     d3 varchar(20),
  8.     d4 varchar(20),
  9.     d5 varchar(20),
  10.     d6 varchar(20),
  11.     d7 varchar(20)
  12. );
MySQL列转行巧录数据

类似于红框的部分,都是连续的节目,需要合并时间段。
下表是模拟开发同事最终录入数据的表。

  1. create table target(
  2.         id int primary key auto_increment,
  3.         channel varchar(32) comment '电台名称',
  4.         d int comment '1-7 表示星期一或者星期二...',
  5.         starttime time comment '节目开始时间',
  6.         endtime time comment '节目结束时间',
  7.         program varchar(32) comment '节目名称'
  8. );

录入的SQL

  1. insert into target(channel,d,program,starttime,endtime)   
  2. select '中国之声',1,d1,min(starttime),max(endtime) from (  
  3.     SELECT @gid := @cgid, @cgid := t.d1, if(@gid = @cgid, @rank,@rank := @rank + 1) AS rank, t.* from   
  4.     (select id,starttime,endtime,d1 from t  order by id) t ,(SELECT @gid := 1, @cgid := 1, @rank := 0) t2  
  5. ) t4 group by d1,rank  
  6. union all  
  7. select '中国之声',2,d2,min(starttime),max(endtime) from (  
  8.     SELECT @gid := @cgid, @cgid := t.d2, if(@gid = @cgid, @rank,@rank := @rank + 1) AS rank, t.* from   
  9.     (select id,starttime,endtime,d2 from t  order by id) t ,(SELECT @gid := 1, @cgid := 1, @rank := 0) t2  
  10. ) t4 group by d2,rank  
  11. union all  
  12. select '中国之声',3,d3,min(starttime),max(endtime) from (  
  13.     SELECT @gid := @cgid, @cgid := t.d3, if(@gid = @cgid, @rank,@rank := @rank + 1) AS rank, t.* from   
  14.     (select id,starttime,endtime,d3 from t  order by id) t ,(SELECT @gid := 1, @cgid := 1, @rank := 0) t2  
  15. ) t4 group by d3,rank  
  16. union all  
  17. select '中国之声',4,d4,min(starttime),max(endtime) from (  
  18.     SELECT @gid := @cgid, @cgid := t.d4, if(@gid = @cgid, @rank,@rank := @rank + 1) AS rank, t.* from   
  19.     (select id,starttime,endtime,d4 from t  order by id) t ,(SELECT @gid := 1, @cgid := 1, @rank := 0) t2  
  20. ) t4 group by d4,rank  
  21. union all  
  22. select '中国之声',5,d5,min(starttime),max(endtime) from (  
  23.     SELECT @gid := @cgid, @cgid := t.d5, if(@gid = @cgid, @rank,@rank := @rank + 1) AS rank, t.* from   
  24.     (select id,starttime,endtime,d5 from t  order by id) t ,(SELECT @gid := 1, @cgid := 1, @rank := 0) t2  
  25. ) t4 group by d5,rank  
  26. union all  
  27. select '中国之声',6,d6,min(starttime),max(endtime) from (  
  28.     SELECT @gid := @cgid, @cgid := t.d6, if(@gid = @cgid, @rank,@rank := @rank + 1) AS rank, t.* from   
  29.     (select id,starttime,endtime,d6 from t  order by id) t ,(SELECT @gid := 1, @cgid := 1, @rank := 0) t2  
  30. ) t4 group by d6,rank  
  31. union all  
  32. select '中国之声',7,d7,min(starttime),max(endtime) from (  
  33.     SELECT @gid := @cgid, @cgid := t.d7, if(@gid = @cgid, @rank,@rank := @rank + 1) AS rank, t.* from   
  34.     (select id,starttime,endtime,d7 from t  order by id) t ,(SELECT @gid := 1, @cgid := 1, @rank := 0) t2  
  35. ) t4 group by d7,rank; 

查看结果
MySQL列转行巧录数据


这个方法看着步骤比较多,其实还是很省事儿的.
主要的工作就是把Excel导入数据库,导入之后的合并,使用同一个SQL改改就好。没啥工作量。
否则使用JAVA解析,还需要自己合并时间段.也不是一个轻松的事情.

该同学需要录入 这种Excel 大致20多个..我觉得我这个方法核心步骤可以复用,应该还是很有效率的。

正文到此结束
Loading...