오라클 데이터베이스에서 쉼표로 구분된 데이터 변환
많은 데이터 조작 작업에서는 더 쉬운 분석을 위해 단일 열 내의 쉼표로 구분된 값(CSV)을 개별 행으로 변환해야 합니다. Oracle은 이를 달성하기 위해 여러 가지 접근 방식을 제공합니다.
방법 1: 정규식을 사용한 재귀 SQL
이 기술은 효율적인 CSV 분할을 위해 정규식과 결합된 재귀 SQL 쿼리를 사용합니다.
<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>
이 쿼리는 쉼표로 구분된 각 값을 반복적으로 추출하여 각각에 대해 새 행을 생성하고 수준 표시기를 포함합니다.
방법 2: 정규 표현식이 없는 재귀 SQL(CTE)
보다 표준적인 SQL 접근 방식은 공통 테이블 표현식(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>
이 재귀 CTE는 이전 방법과 동일한 결과를 얻지만 정규 표현식에 의존하지 않습니다.
방법 3: 비재귀적 접근 방식(INSTR 및 SUBSTR)
비재귀적 대안은 INSTR()
및 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>
이 방법은 반복적으로 쉼표 위치를 찾고 부분 문자열을 추출하여 문제에 대한 다른 접근 방식을 제공합니다.
최적의 방법은 특정 데이터 및 성능 요구 사항에 따라 다릅니다. Oracle 환경에 가장 효율적인 솔루션을 결정하려면 각 접근 방식을 테스트해 보세요.
위 내용은 Oracle에서 쉼표로 구분된 값을 행으로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!