前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >尽量使用LISTAGG代替WM_CONCAT

尽量使用LISTAGG代替WM_CONCAT

作者头像
overme
发布2022-01-17 08:01:30
3.4K0
发布2022-01-17 08:01:30
举报
文章被收录于专栏:数据开发笔记

Oracle

尽量使用LISTAGG代替WM_CONCAT

测试数据

代码语言:javascript
复制
SELECT * FROM TEST_IGNORE;
image-20211129181336313
image-20211129181336313

使用wm_concat

代码语言:javascript
复制
SELECT T.RCLASS,
       WMSYS.WM_CONCAT(T.BANK) AS BANK
FROM TEST_IGNORE T
GROUP BY T.RCLASS;
image-20211129181454778
image-20211129181454778

去重后

代码语言:javascript
复制
SELECT T.RCLASS,
       WMSYS.WM_CONCAT(distinct T.BANK) AS BANK
FROM TEST_IGNORE T
GROUP BY T.RCLASS;
image-20211129181444560
image-20211129181444560

使用listagg

代码语言:javascript
复制
SELECT t.rclass,
       LISTAGG( t.bank,',') WITHIN GROUP(order by t.id) as BANK
FROM TEST_IGNORE t
GROUP BY T.RCLASS;
image-20211129182219575
image-20211129182219575

listagg去重

代码语言:javascript
复制
SELECT T.RCLASS,
       LISTAGG(T.BANK, ',') WITHIN GROUP(ORDER BY T.ID) AS BANK
FROM (SELECT T.RCLASS,
             T.BANK,
             T.ID
      FROM (SELECT T.RCLASS,
                   T.BANK,
                   T.ID,
                   ROW_NUMBER() OVER(PARTITION BY T.RCLASS, T.BANK ORDER BY T.ID) AS RN
            FROM TEST_IGNORE T) T
      WHERE RN = 1) T
GROUP BY RCLASS;
image-20211129182819707
image-20211129182819707
  1. wm_concat可能会因为数据库版本的不同 返回clob或者varcahr2字段,增加线上报错概率比如ORA-22922
  2. wm_concat聚合的字段没有固定的顺序,listagg可以根据字段排序
  3. listagg的性能比wm_concat好
  4. wm_concat函数是可以支持distinct的,但是listagg分析函数是不支持distinct的,只能先去重再聚合

本站文章除注明转载/出处外,均为本站原创,转载前请务必署名,转载请标明出处 最后编辑时间为: 2021/11/29 18:37:29

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/11/29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 尽量使用LISTAGG代替WM_CONCAT
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档