oracle多行合为一行,ORACLE多行合并为一行

本文演示了如何使用Oracle的分析函数row_number()和sys_connect_by_path将同一部门的员工姓名合并为一行记录。通过为deptno分配row_number(),然后使用递归查询connect by和sys_connect_by_path串联ename,最终通过再次应用row_number()按curr_level降序排列,筛选出每部门ename_path_rank为1的数据,实现多行到单行的转换。
摘要由CSDN通过智能技术生成

demo场景,以oracle自带库中的表emp为例:

select ename,deptno from emp order by deptno;

ENAME

DEPTNO

CLARK

10

KING

10

MILLER

10

SMITH

20

ADAMS

20

FORD

20

SCOTT

20

JONES

20

ALLEN

30

BLAKE

30

MARTIN

30

JAMES

30

TURNER

30

WARD

30

现在想要将同一部门的人给合并成一行记录,如何做呢?如下:

ENAME

DEPTNO

CLARK,KING,MILLER

10

ADAMS,FORD,JONES,SCOTT,SMITH

20

ALLEN,BLAKE,JAMES,MARTIN,TURNER,WARD

30

通常我们都是自己写函数或在程序中处理,这里我们利用oracle自带的分析函数row_number()和sys_connect_by_path来进行sql语句层面的多行到单行的合并,并且效率会非常高。

基本思路:

1、对deptno进行row_number()按ename排位并打上排位号

select deptno,ename,row_number() over(partition by deptno order by deptno,ename) rank

from emp order by deptno,ename;

DEPTNO

ENAME

RANK

10

CLARK

1

10

KING

2

10

MILLER

3

20

ADAMS

1

20

FORD

2

20

JONES

3

20

SCOTT

4

20

SMITH

5

30

ALLEN

1

30

BLAKE

2

30

JAMES

<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值