1.前言
最近因项目需求,需要把员工的工作组返回给前台,但是数据库是把员工的工作组Id,都存在一个字段内了(以“逗号”分隔),而这样不符合前台的需要,他们需要一行,一行的数据。如:
数据库:
userId, workgroup 1001 10,12,15 1002 2,4,5
前台需要:
userId, workgroup 1001 10 1001 12 1001 15 1002 2 1002 4 1002 5
2. 分析思路:
大体的思路是这样的:
首先:要知道,每一员工最多有多少个组。
其次:建一个有关“数”的临时表,与上面的组数进行关联,这样就出现了“多”行
最后:多“行”有了,剩下的就是对每一行的组进行刷选。如第一行取第一个逗号左边的,第二行取第二个逗号左边的, 依此类推。
3. 实现:
根据上次的思路,来实现:
第一步:
with v_usergroups as (select as userId, as workgroups from dual union select as userId, as workgroups from dual ) select userid, || workgroups || AS tempgroups,length(workgroups || ) - nvl(length(REPLACE(workgroups, )), 0) AS groupcount FROM v_usergroups
PS: 这里在"workgroup" 的前后也加了逗号,是为了后面使用方面。
第二步:
select LEVEL lv from dual CONNECT BY LEVEL