分组合并多列

WBOY
Lepaskan: 2016-06-07 14:56:31
asal
1310 orang telah melayarinya

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
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(字符串列,',')),','),',')
Salin selepas log masuk
Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan