Значения столбца в строке
У меня есть следующая таблица
id count hour age range
-------------------------------------
0 5 10 61 10-200
1 6 20 61 10-200
2 7 15 61 10-200
5 9 5 61 201-300
7 10 25 61 201-300
0 5 10 62 10-20
1 6 20 62 10-20
2 7 15 62 10-20
5 9 5 62 21-30
1 8 6 62 21-30
7 10 25 62 21-30
10 15 30 62 31-40
Мне нужно выбрать различные значения диапазона столбца, я попытался следующий запрос
Select distinct range as interval from table name where age = 62;
его результат в столбце:
interval
----------
10-20
21-30
31-41
Как я могу получить результат следующим образом?
10-20, 21-30, 31-40
Отредактировано: я сейчас пытаюсь следующий запрос:
select sys_connect_by_path(range,',') interval
from
(select distinct NVL(range,'0') range , ROW_NUMBER() OVER (ORDER BY RANGE) rn
from table_name where age = 62)
where connect_by_isleaf = 1 CONNECT BY rn = PRIOR rn+1 start with rn = 1;
Который дает мне вывод как:
Interval
----------------------------------------------------------------------------
, 10-20,10-20,10-20,21-30,21-30, 31-40
Ребята, плз, помогите мне получить желаемый результат.
1 ответ
Если вы используете 11.2, а не только 11.1, вы можете использовать LISTAGG
агрегатная функция
SELECT listagg( interval, ',' )
WITHIN GROUP( ORDER BY interval )
FROM (SELECT DISTINCT range AS interval
FROM table_name
WHERE age = 62)
Если вы используете более раннюю версию Oracle, вы можете использовать один из других методов объединения строк Oracle на странице Тима Холла. До 11.2 я лично хотел бы создать пользовательскую статистическую функцию, чтобы вы могли
SELECT string_agg( interval )
FROM (SELECT DISTINCT range AS interval
FROM table_name
WHERE age = 62)
Однако, если вы не хотите создавать функцию, вы можете использовать подходы ROW_NUMBER и SYS_CONNECT_BY_PATH, хотя следовать за этим становится немного сложнее.
with x as (
SELECT DISTINCT range AS interval
FROM table_name
WHERE age = 62 )
select ltrim( max( sys_connect_by_path(interval, ','))
keep (dense_rank last order by curr),
',') range
from (select interval,
row_number() over (order by interval) as curr,
row_number() over (order by interval) -1 as prev
from x)
connect by prev = PRIOR curr
start with curr = 1