postgresql:字符串累加拼接(聚合分组拼接)

问题:

有时,想要将某字段在查询列表的时候,按分组的不同,同组字符串累加拼接起来。

原表数据内容如下:

想要达到的目标结果:是把cdate_tno的字符串分组累加拼接起来,如下:

解决方案:

使用聚合函数 string_agg,示例如下:

SELECT string_agg(cdate_tno, ',')cdate_tno,arch_id FROM t_month_bill
GROUP BY arch_id

string_agg(cdate_tno, ',')中第一个参数是需要聚合拼接的字段名(或表达式),第二个参数是拼接间隔符号,这里用的是逗号。

如果聚合的时候想按排序添加,可以在第二个参数后面空格再加上order by 语句。如下:

SELECT string_agg(cdate_tno, ',' order by cdate_tno)cdate_tno,arch_id FROM t_month_bill
GROUP BY arch_id

关于出现“,,,,,,,,,” 的问题

若聚合字段是空字符串时,聚合查询后会出现“,,,,,,,,”的字段的显示,这时就需要用case when将空字符串转为Null。

处理前

SELECT string_agg(case when cdate_tno!='' then cdate_tno else null end, ',' order by cdate_tno)cdate_tno,arch_id
FROM t_month_bill
GROUP BY arch_id

此处使用case when 将空字符串转为Null,处理后

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋斗鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值