pg 多列合并一列

 

下面是正常的查询多条数据,如果我要合并成列怎么办。

   

  其实pg有自带的array_to_string函数 ,但是写法稍微有点麻烦,但是可以根据array_to_string函数自定义一个函数去简化写法。

1
2
3
4
5
CREATE AGGREGATE group_concat(anyelement)(
sfunc = array_append,
stype = anyarray,
initcond = '{}'
); 

  然后使用函数去指定字符串去分割就行了    

  

 

  pg9.x版本可以用函数string_agg实现

1
select string_agg(bm,'.') as codePath from table

  
  oracle使用listagg函数实现

1
2
3
4
select listagg(bm,'.') WITHIN GROUP(ORDER BY bm) as cxmlj  
from table
start with bm = '150203740000'
connect by  prior  ssjgid = zzjgid

  

posted @   不是安逸  阅读(1510)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
点击右上角即可分享
微信分享提示