집 >데이터 베이스 >MySQL 튜토리얼 >Oracle에서 쉼표로 구분된 값을 행으로 어떻게 구분할 수 있습니까?
Oracle 데이터베이스에서 쉼표로 구분된 데이터 변환
Oracle 데이터베이스는 데이터를 단일 열 내에 쉼표로 구분된 값으로 저장하는 경우가 많아 효율적인 데이터 조작 및 검색을 방해합니다. 이 기사에서는 쉼표로 구분된 데이터를 개별 행으로 효과적으로 변환하여 데이터 분석 및 처리를 개선하는 여러 가지 방법을 제시합니다.
방법 1: 정규식을 사용한 재귀 쿼리
이 우아한 솔루션은 효율적인 값 추출을 위해 재귀 쿼리와 정규식을 사용합니다.
<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>
CONNECT BY
절은 쉼표로 구분된 값을 반복하는 반면 REGEXP_SUBSTR
은 각 하위 문자열을 추출합니다.
방법 2: CTE를 사용한 ANSI 규격 접근 방식
향상된 이식성을 위해 공통 테이블 표현식(CTE)은 ANSI 호환 대안을 제공합니다.
<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: 정규 표현식을 사용하지 않는 재귀적 접근
세 번째 옵션은 정규식을 피하고 문자열 조작에만 의존합니다.
<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
을 사용하여 값을 추출합니다.
이러한 기술은 Oracle 데이터베이스 내에서 쉼표로 구분된 값을 행으로 변환하는 효율적이고 안정적인 솔루션을 제공하여 향상된 데이터 처리 및 분석을 촉진합니다.
위 내용은 Oracle에서 쉼표로 구분된 값을 행으로 어떻게 구분할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!