达梦group_concat函数替代

本文探讨了SQL中wm_concat()与group_concat()函数的使用,wm_concat()用于拼接字符串,group_concat()则支持分组聚合。当需要自定义分隔符时,可以结合replace()函数。同时,listagg()WITHIN GROUP()函数被介绍,它不仅能够聚合,还能进行排序和分隔符替换,如示例所示,展示了如何根据创建时间对用户名称进行排序并用点号连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

可替换为wm_concat()
默认为逗号分隔,如果想其他符号要重写函数或者用replace()函数包裹替换,例如:

select replace( wm_concat( user_name),',','|') from zhmx_data_bzbb.tb_clue

按group_concat的语法会报错非法参数

//会报错
select wm_concat( user_name,'|') from zhmx_data_bzbb.tb_clue

如果还想支持排序,或者支持替换分隔符,也可以使用listagg() WITHIN GROUP ()函数
举例如下

select listagg( user_name,'.') within group (order by create_time) from zhmx_data_bzbb.tb_clue

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值