您好,欢迎来到爱站旅游。
搜索
您的当前位置:首页分组合并多列

分组合并多列

来源:爱站旅游

Oracle9i及以前的版本中,没有可直接支持的分组后,用某个特殊字符进行分隔列 像10g有wm_concat,11g可以用listagg(字段,分隔字符) within group(order by 字段) Oracle SELECT 分组列,ltrim(MAX(sys_connect_by_path(字符串列,',')),',')FROM (SELECT 分组列

Oracle9i及以前的版本中,没有可直接支持的分组后,用某个特殊字符进行分隔列
像10g有wm_concat,11g可以用listagg(字段,分隔字符) within group(order by 字段)
Oracle $velocityCount-->
SELECT 分组列,ltrim(MAX(sys_connect_by_path(字符串列,',')),',')
FROM (
SELECT 分组列,字符串列,rank()over(ORDER BY 分组列) + row_number()over(order by 分组列) RN,row_number()over(partition by 分组列 order by 分组列) RM
FROM 表)
start with RM=1
connect by prior RN=RN-1
group by
分组列
;

--在FROM 表这个地方你可以过滤掉这些空值
--或在ltrim(MAX(sys_connect_by_path(字符串列,',')),',')这个地方

--再加个这个就可以rtrim(ltrim(MAX(sys_connect_by_path(字符串列,',')),','),',')

Copyright © 2019- azee.cn 版权所有

违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务