问题描述
各位专家好,
我正在准备一些存储过程,并且需要将结果分组为带有任何分隔符的字符串。这里的挑战是我没有任何列 (具有相同的数据) 要分组。下面是我的场景。
我已经有一个解决方案,通过使用子查询,并想知道是否有任何其他方法来实现这一点。
选择CONTACT_NO FROM (选择CONTACT_NO,'col3' TEMP from contacts) 按TEMP分组;
谢谢,
拉杰。
我正在准备一些存储过程,并且需要将结果分组为带有任何分隔符的字符串。这里的挑战是我没有任何列 (具有相同的数据) 要分组。下面是我的场景。
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:
但是,当您停留在10g上时,您将不得不使用一种解决方法,例如使用Tom的stragg() 函数:
https://asktom.oracle.com/pls/asktom/f?p=100:11:0::::p11_question_id:2196162600402
从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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




