Concat значение второго столбца, если значение первого столбца совпадает
У меня есть запрос, как показано ниже, и в списке вывод его:
SELECT DISTINCT TRACKING_NUM,TITLE_OF_DOC_SEC
FROM some_table
WHERE TRACKING_NUM IS NOT NULL;
о / р:
TRACKING_NUM TITLE_OF_DOC_SEC
007 Email Flow
007 Test Bug 53306
007 Title 1119
007 Title Test
007 test bug
009 1156
089 Title 21173
098 test Doc Section
Я хочу переписать запрос так, чтобы вывод был таким:
TRACKING_NUM TITLE_OF_DOC_SEC
007 Email Flow,Test Bug 53306,Title 1119,Title Test,test bug
009 1156
089 Title 21173
098 test Doc Section
кто-нибудь может помочь?
3 ответа
Решение
Используйте Listagg() в 11g или WM_Concat() в 10g:
SELECT LISTAGG(TITLE_OF_DOC_SEC, ',') WITHIN GROUP (ORDER BY TRACKING_NUM) AS TITLE_OF_DOC_SEC
FROM your table
WHERE....
SELECT WM_CONCAT(TITLE_OF_DOC_SEC) AS TITLE_OF_DOC_SEC
FROM your table
WHERE....
Если вы используете Oracle 11g+, то вы можете использовать LISTAGG()
:
SELECT TRACKING_NUM,
LISTAGG(TITLE_OF_DOC_SEC, ', ') WITHIN GROUP (ORDER BY TRACKING_NUM) AS TITLE_OF_DOC_SEC
FROM some_table
WHERE TRACKING_NUM IS NOT NULL
GROUP BY TRACKING_NUM;
Смотрите SQL Fiddle с демо
В 11g Listagg это лучший вариант:
SQL> select tracking_num,
2 listagg(title_of_doc_sec,',') within group (order by title_of_doc_sec) title_of_doc_sec
3 from (select distinct tracking_num , title_of_doc_sec from some_table)
4 group by tracking_num;
TRA TITLE_OF_DOC_SEC
--- ----------------------------------------------------------------------
007 Email Flow,Test Bug 53306,Title 1119,Title Test,test bug
009 1156
089 Title 21173
098 test Doc Section
10 г вы можете использовать wm_concat
(но учтите, что это не задокументировано):
SQL> select tracking_num,
2 wm_concat(title_of_doc_sec) title_of_doc_sec
3 from (select distinct tracking_num , title_of_doc_sec from some_table)
4 group by tracking_num;
TRA TITLE_OF_DOC_SEC
--- ----------------------------------------------------------------------
007 Title Test,test bug,Title 1119,Email Flow,Test Bug 53306
009 1156
089 Title 21173
098 test Doc Section
или даже модельное предложение:
SQL> with data as (select distinct tracking_num , title_of_doc_sec from some_table)
2 select tracking_num, title_of_doc_sec
3 from (select *
4 from data
5 model
6 partition by (tracking_num)
7 dimension by (row_number() over (partition by tracking_num order by title_of_doc_sec) rn)
8 measures (title_of_doc_sec t, cast(null as varchar2(4000)) title_of_doc_sec,
9 count(*) over (partition by tracking_num) cnt)
10 rules(
11 title_of_doc_sec[any] = case when t[cv() - 1 ] is null
12 then t[cv()]
13 else title_of_doc_sec[cv()-1]||', '|| t[cv()]
14 end
15 ))
16 where cnt = rn;
TRA TITLE_OF_DOC_SEC
--- ----------------------------------------------------------------------
007 Email Flow, Test Bug 53306, Title 1119, Title Test, test bug
009 1156
089 Title 21173
098 test Doc Section