求一条sql,请大家帮忙,谢谢

haiercs 2012-05-06 09:24:55
A表:
员工 科室 登记日期
张三 胸外科,皮肤科 2000-11-19
李四 胸外科 2001-01-04
王五 妇产科,骨科 2001-01-08
求一条sql,让其结果如下显示
A表:
员工 科室 登记日期
张三 胸外科 2000-11-19
张三 皮肤科 2000-11-19
李四 胸外科 2001-01-04
王五 妇产科 2001-01-08
王五 骨科 2001-01-08

即A表员工属于多个科室的是在一行上用逗号分隔的,现在要把这种形式换成用增加行的形式来解决,属于多个科室就有多行记录
...全文
202 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
都是高手 啊!
softwakaka 2012-05-09
  • 打赏
  • 举报
回复
2楼3楼正解。 字符串转列1.substr + instr,2.regexp_substr
  • 打赏
  • 举报
回复

with t1 as
(
select '张三' c1,'胸外科,皮肤科' c2,date'2000-11-19' c3 from dual
union all
select '李四','胸外科',date'2001-01-04' from dual
union all
select '王五','妇产科,骨科',date'2001-01-08' from dual
)

select c1,
  substr(','||c2||',',instr(','||c2,',',1,b.rn)+1,
  instr(c2||',',',',1,b.rn)-instr(','||c2,',',1,b.rn)) c2,c3
from t1,
  (select rownum rn from t1
  connect by rownum<10) b
  where length(c2)-length(replace(c2,','))+1>=b.rn
order by c1,b.rn

c1 c2 c3
-----------------------------------------------
1 李四 胸外科 2001/1/4
2 王五 妇产科 2001/1/8
3 王五 骨科 2001/1/8
4 张三 胸外科 2000/11/19
5 张三 皮肤科 2000/11/19

hupeng213 2012-05-06
  • 打赏
  • 举报
回复
一句SQL解决不了,需要写存储过程,用游标来逐行分解。
nonghongjian 2012-05-06
  • 打赏
  • 举报
回复
with t1 as
(
select '张三' c1,'胸外科,皮肤科' c2,date'2000-11-19' c3 from dual
union all
select '李四','胸外科',date'2001-01-04' from dual
union all
select '王五','妇产科,骨科',date'2001-01-08' from dual
)

select c1,
  substr(','||c2||',',instr(','||c2,',',1,b.rn)+1,
  instr(c2||',',',',1,b.rn)-instr(','||c2,',',1,b.rn)) c2,c3
from t1,
  (select rownum rn from t1
  connect by rownum<10) b
  where length(c2)-length(replace(c2,','))+1>=b.rn
order by c1,b.rn

c1 c2 c3
-----------------------------------------------
1 李四 胸外科 2001/1/4
2 王五 妇产科 2001/1/8
3 王五 骨科 2001/1/8
4 张三 胸外科 2000/11/19
5 张三 皮肤科 2000/11/19

coolkisses 2012-05-06
  • 打赏
  • 举报
回复
借上面的数据用一下


with t1 as
(
select '张三' c1,'胸外科,皮肤科,骨科1,骨科2,骨科3,骨科4,骨科5,骨科6,骨科7,骨科8,骨科9,骨科10,骨科11,骨科12,骨科13,骨科14,骨科15,骨科16,骨科17' c2,date'2000-11-19' c3 from dual
union all
select '李四','胸外科',date'2001-01-04' from dual
union all
select '王五','妇产科,骨科',date'2001-01-08' from dual
)


select DISTINCT c1
,c3
,REPLACE( -- 去除多余的【,】
regexp_substr(c2||',' ,'.*?'||'[,]' ,1 ,LEVEL) -- 截取 ,【科室】,
,',') "科室"
from t1
connect by level <= nvl(
length(regexp_replace(c2,'[^,]','')) + 1
,1)
order by c1;

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧