码迷,mamicode.com
首页 > 数据库 > 详细

Oracle多行记录合并处理

时间:2014-12-27 08:56:26      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:

1:效果如下图所示:

技术分享

表T1:

CREATE TABLE T1 
(
  WEEKWORKID VARCHAR2(20) ,
  DD VARCHAR2(20) 
) 

表T2

CREATE TABLE T2 
(
  WEEKWORKID VARCHAR2(20) ,
  NR VARCHAR2(20) 
)

SQL语句:

select t2.weekworkid,t2.nr,T.dd
from t2
left join (
  -- 4筛选结果集
  select weekworkid,max(substr(dd,2))dd
  from(
    -- 3使用sys_connect_by_path生成结果集
    select weekworkid,sys_connect_by_path(dd,,)dd
    from(
      -- 2创建子节点与父节点
      select weekworkid,dd,weekworkid||rn rchild,weekworkid||(rn-1)rfather
      from(
        -- 1对记录添加序号
        select t1.weekworkid,t1.dd,row_number() 
            over(partition by t1.weekworkid order by t1.dd) rn 
        from t1
        where t1.weekworkid in(
          select weekworkid from t2
        )
      )
    )connect by prior rchild = rfather start with rfather like %0
  ) group by weekworkid
)T on t2.weekworkid=T.weekworkid
order by weekworkid

运行结果:

技术分享

Oracle多行记录合并处理

标签:

原文地址:http://www.cnblogs.com/yshyee/p/4187989.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!