postgresql合并string_agg函数

1 有时候我们会需要将多条数据根据一些特别的字段做一些合并。比如下面这个查询,正常会查询出3条数据,但是我们会希望根据create_by 分成两列显示

2 这时候需要用到string_agg函数,先通过group by分组,在进行合并,当然查询结果需要满足group  by的限制;sql语句:

select create_by,string_agg(videoname,',') as videonames from w008_video_addr_info where id in (4248,538,546)
group by create_by

查询结果:

3 复杂一些的应用场景(子查询):

下面的语句是我用来查询一个学生在什么时间看了哪些视频:

select 
	sa.id,
	info.nickname,  
	(select string_agg(v.videoname,',')  
		from w008_school_assign_video sv   
		join w008_video_addr_info v on sv.videoaddrinfo =v.id 
		where sv.schoolassignment=sa.id and v.is_removed=0 and sv.is_removed=0  
		group by v.is_removed) as videos,
    (select string_agg(to_char(sv.create_date, 'MM-DD HH24:MI'),',')  
		from w008_school_assign_video sv  
		join w008_video_addr_info v on sv.videoaddrinfo =v.id  where         
        sv.schoolassignment=sa.id and v.is_removed=0  
		and sv.is_removed=0 group by v.is_removed) as viewtime 
from w008_school_assignment sa   
join w008_user_business_info info on sa.userlongid=info.id  where sa.shchoolworkid=2514505674916356

结果:

当然,string_agg(field,'分隔符');分隔符可以填写其他任意的字符,方便后期处理即可;

 

  • 2
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值