>데이터 베이스 >MySQL 튜토리얼 >Oracle에서 쉼표로 구분된 값을 행으로 변환하는 방법은 무엇입니까?

Oracle에서 쉼표로 구분된 값을 행으로 변환하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-22 19:11:09337검색

How to Convert Comma-Separated Values into Rows in Oracle?

Oracle에서 쉼표로 구분된 값을 행으로 변환

쉼표는 여러 값을 단일 문자열로 표시하기 위한 일반적인 구분 기호이지만 Oracle에서 데이터 작업을 할 때는 이러한 값을 서로 다른 행으로 구분해야 할 수도 있습니다. 이는 다양한 방법으로 달성될 수 있습니다.

정규식을 사용한 재귀 쿼리

한 가지 방법은 정규식과 함께 재귀 쿼리를 사용하여 각 값을 추출하는 것입니다.

<code class="language-sql">select distinct id, trim(regexp_substr(value, '[^,]+', 1, level) ) value, level
from tbl1
connect by regexp_substr(value, '[^,]+', 1, level) is not null
order by id, level;</code>

이 쿼리는 REGEXP_SUBSTR 함수를 사용하여 쉼표가 아닌 각 하위 문자열을 추출한 다음 재귀 쿼리를 사용하여 결과를 연결합니다.

정규 표현식이 없는 재귀 쿼리

정규식 사용을 피하는 또 다른 재귀적 접근 방식:

<code class="language-sql">WITH t ( id, value, start_pos, end_pos ) AS
  ( SELECT id, value, 1, INSTR( value, ',' ) FROM tbl1
  UNION ALL
  SELECT id,
    value,
    end_pos                    + 1,
    INSTR( value, ',', end_pos + 1 )
  FROM t
  WHERE end_pos > 0
  )
SELECT id,
  SUBSTR( value, start_pos, DECODE( end_pos, 0, LENGTH( value ) + 1, end_pos ) - start_pos ) AS value
FROM t
ORDER BY id,
  start_pos;</code>

이 쿼리는 INSTR 함수를 사용하여 쉼표의 위치를 ​​찾은 다음 SUBSTR 함수를 사용하여 개별 값을 추출합니다.

재귀적 합집합을 사용한 CTE

세 번째 방법은 재귀 공용체와 함께 공통 테이블 표현식(CTE)을 사용합니다.

<code class="language-sql">with t (id,res,val,lev) as (
           select id, trim(regexp_substr(value,'[^,]+', 1, 1 )) res, value as val, 1 as lev
             from tbl1
            where regexp_substr(value, '[^,]+', 1, 1) is not null
            union all           
            select id, trim(regexp_substr(val,'[^,]+', 1, lev+1) ) res, val, lev+1 as lev
              from t
              where regexp_substr(val, '[^,]+', 1, lev+1) is not null
              )
select id, res,lev
  from t
order by id, lev;</code>

이 쿼리는 UNION ALL 연산자를 사용하여 쉼표가 아닌 모든 하위 문자열을 추출하는 재귀 CTE를 생성합니다.

위 내용은 Oracle에서 쉼표로 구분된 값을 행으로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.