最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oralce按分隔符把一列转成多行

来源:懂视网 责编:小采 时间:2020-11-09 10:31:17
文档

Oralce按分隔符把一列转成多行

Oralce按分隔符把一列转成多行:1.前言 最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以ldquo;逗号 1.前言 最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以“逗号
推荐度:
导读Oralce按分隔符把一列转成多行:1.前言 最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以ldquo;逗号 1.前言 最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以“逗号

1.前言 最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以ldquo;逗号

1.前言

  最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以“逗号”分隔),而这样不符合前台的需要,他们需要一行,一行的数据。如:

  数据库:

userId, workgroup ,4,5

  前台需要:

userId, workgroup

2. 分析思路:

  大体的思路是这样的:

  首先:要知道,每一员工最多有多少个组。

  其次:建一个有关“数”的临时表,与上面的组数进行关联,这样就出现了“多”行

  最后:多“行”有了,剩下的就是对每一行的组进行刷选。如第一行取第一个逗号左边的,,第二行取第二个逗号左边的, 依此类推。

3. 实现:

  根据上次的思路,来实现:

  第一步: 

userId,workgroups from dual userId,workgroups from dual ) workgroups tempgroups,length(workgroups ) )), 0) AS groupcount FROM v_usergroups

  PS: 这里在"workgroup" 的前后也加了逗号,是为了后面使用方面。

  第二步:

  PS:这里的5,我们是根据业务需要,每一员工最多分为5个组,当然也可以写其他的值,但一定要大于第一步求得的"groupcount".

  到这里后,我们对这两个表进行关联,看看值怎么样:

userId,workgroups from dual userId,workgroups from dual ) (workgroups tempgroups,length(workgroups ) )), 0) AS groupcount FROM v_usergroups ) a, () b where b.lv<=a.groupcount order by userid,lv

USERID TEMPGROUPS GROUPCOUNT LV ,,,,,2,4,5, 3 3

  到这里,就离我们最终的结果很近了。 只需要在外层对"tempgroups"做一下简单的处理就可以了:

  第三步:

    这一步的主要思路就是:截串。第一个组应该是第一逗号和第二个逗号之间的值,第二个组应该是第二个逗号与第三个逗号之间的值,那第一个,和第二个如何表示呢,其实就是利用字段lv。也就是:

    substr(tempgroups,instr(tempgroups, ',', 1, lv) + 1,instr(tempgroups, ',', 1, lv + 1) - (instr(tempgroups, ',', 1, lv) + 1))

    最后的SQL 如下:

userId,workgroups from dual userId,workgroups from dual ) , , , 1, lv) + 1)) from (workgroups tempgroups,length(workgroups ) )), 0) AS groupcount FROM v_usergroups ) a, () b where b.lv<=a.groupcount order by userid,lv

linux

文档

Oralce按分隔符把一列转成多行

Oralce按分隔符把一列转成多行:1.前言 最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以ldquo;逗号 1.前言 最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以“逗号
推荐度:
标签: 分隔 oracle 一列
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top