取消oracle分组方式,Oracle 分组合并连接字符串的方法

方法一:wmsys.wm_concat(column)

介绍:其函数在Oracle 10g推出,在10g版本中,返回字符串类型,在11g版本中返回clob类型。括号里面的参数是列,而且可以是多个列的集合,也就是说在括号里面可以自由地用‘||’合并字符串。如下面的例子:

Select u_id, wmsys.wm_concat(goods ||

'(' || num || '斤)' ) goods_sum from shopping group by u_id

方法二:listagg (column,[,]) within group (order by ) [over

(partition by  )]

介绍:其函数在Oracle 11g

版本中推出,对分组后的数据按照一定的排序进行字符串连接。其中,“[,]”表示字符串连接的分隔符,如果选择使用[over

(partition by )]则会使其变成分析函数;

方法三:sys_connect_by_path(column,)

介绍:其函数在Oracle 9i 版本中推出,用来合并链路的字符串。注意的是其一定要和connect by子句合用!第一个参数是形成树形式的字段,第二个参数是父级和其子级分隔显示用的分隔符。

下面是上面几种方法的实例(在Oracle

11g版本中运行正确):

实例:

方法一:用listagg(,',') within

group()

SQL

code

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

WITH temp1 AS(

select 'a' as username,1 as deptid from dual union all

select 'b',1 from dual union all

select 'c',1 from dual union all

select 'd',2 from dual union all

select 'e',2 from dual

),

temp2 AS(

select 1 as deptid,'部门1' as deptname from dual union all

select 2 ,'部门2' from dual

)

select p.deptid,

listagg(t.username,',') within

group (order by t.username) as username,

p.deptname

from temp1 t,temp2

p

where t.deptid=p.deptid

group by p.deptid,p.deptname

order by p.deptid

-------------------------

deptid userName

deptName

1 a,b,c 部门1

2 d,e 部门2

方法二:用wm_concat()

SQL

code

1

2

3

4

5

6

7

8

9

10

select p.deptid,

wm_concat(t.username) as

username,

p.deptname

from temp1 t,temp2

p

where t.deptid=p.deptid

group by p.deptid,p.deptname

order by p.deptid

方法三:用CONNECT BY

SQL

code

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

select deptid,

ltrim(max(sys_connect_by_path(username,',')),','),

deptname

from (

select p.deptid,t.username,p.deptname,

row_number()over(partition by

t.deptid order by t.username) as ar

from temp1 t,temp2

p

where t.deptid=p.deptid

)

start with ar=1

connect by prior ar=ar-1

and username=prior username

group by deptid,deptname

order by deptid

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------

--------------如有错误,请指教!

--------------技术交流QQ:1732035211

-------------技术交流邮箱:1732035211@qq.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle中,可以使用ROW_NUMBER()函数和PARTITION BY子句来对数据进行分组和排序。引用\[1\]中的示例代码展示了如何使用ROW_NUMBER()函数和PARTITION BY子句来对表中的数据进行分组,并为每个分组的记录标记序号。通过在子查询中使用ROW_NUMBER()函数,可以为每个分组的记录添加一个序号,并使用WHERE子句筛选出序号小于3的记录。 另外,引用\[2\]中的示例代码展示了如何使用wm_concat()函数来将同一分组内的多个值合并为一个字符串。在这个示例中,使用ROW_NUMBER()函数和PARTITION BY子句对数据进行分组,并使用wm_concat()函数将同一分组内的userName值合并为一个字符串。 最后,引用\[3\]中的示例代码展示了如何使用ROW_NUMBER()函数和PARTITION BY子句对数据进行分组,并使用MAX函数和DECODE函数将同一分组内的多个属性值合并在一条记录中。通过使用ROW_NUMBER()函数和PARTITION BY子句,可以为每个分组的记录添加一个序号,然后使用MAX函数和DECODE函数将不同序号对应的属性值合并在一条记录中。 综上所述,Oracle中可以使用ROW_NUMBER()函数和PARTITION BY子句对数据进行分组和排序,并使用不同的函数(如wm_concat()、MAX和DECODE)将同一分组内的多个值合并在一条记录中。 #### 引用[.reference_title] - *1* *3* [oracle数据库分组,把多条数据合并成一条数据,分几个字段](https://blog.csdn.net/qq_42217505/article/details/104405425)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [oracle 分组合并字段,每组行显示](https://blog.csdn.net/weixin_40841731/article/details/126137252)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值