暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 将没有列的行连接起来分组

askTom 2017-09-07
289

问题描述

各位专家好,

我正在准备一些存储过程,并且需要将结果分组为带有任何分隔符的字符串。这里的挑战是我没有任何列 (具有相同的数据) 要分组。下面是我的场景。


CONTACT_NO     AREA
==========     =====
+4484948498    'BOURNEMOUTH BH1AA'
+4494947499    'BOURNEMOUTH CKKAA'
+4404848598    'BOURNEMOUTH MBKKA'


RESULT
======
+4484948498,+4494947499,+4404848598
复制


我已经有一个解决方案,通过使用子查询,并想知道是否有任何其他方法来实现这一点。

选择CONTACT_NO FROM (选择CONTACT_NO,'col3' TEMP from contacts) 按TEMP分组;


谢谢,
拉杰。


专家解答

我不明白 “无列分组” 有什么意义?

从11.2你可以使用listagg:

with rws as (
  select chr(rownum+64) l from dual
  connect by level <= 3
)
  select listagg(l, ',') within group (order by l) 
  from   rws;

LISTAGG(L,',')WITHINGROUP(ORDERBYL)  
A,B,C 
复制


但是,当您停留在10g上时,您将不得不使用一种解决方法,例如使用Tom的stragg() 函数:

https://asktom.oracle.com/pls/asktom/f?p=100:11:0::::p11_question_id:2196162600402

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论