PostgreSQL聚合函数实现将查到的多条数据合并为一条

本文介绍了在MySQL中使用PostgreSQL的string_agg函数解决用户A在不同科室拥有重复角色问题,最终目标是将结果转化为(A, 科室-角色)的格式,经过多次尝试后成功的方法分享。

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

业务场景:某个用户A对应多个科室的多个角色,角色名可能出现重复,比如中药房科室的药房人员角色和西药房科室的药房人员角色,这种情况下联查的话结果肯定会出现多条:
A 中药房 药房人员
A 西药房 药房人员
A 中药库 药库人员
在这里插入图片描述

而我想要的格式是(A,中药房-药房人员,西药房-药房人员,中药库-药库人员),寻找各种方法经历多次失败之后终于找到了方法,只需要通过PostgreSQL的聚合函数 string_agg做出以下修改(注意看我标注的地方)即可实现要求:
在这里插入图片描述 mysql实现方法:group_concat( [distinct] 要连接的字段 [order by 排序字段 asc/desc ] [separator ‘分隔符’] )

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值