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

Oracle에서 쉼표로 구분된 값을 중복 없이 여러 행으로 분할하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-30 12:32:10546검색

How to Split Comma-Separated Values in Oracle into Multiple Rows Without Duplicates?

Oracle 테이블의 여러 쉼표로 구분된 값을 중복 없이 여러 행으로 분할

Oracle 테이블의 데이터를 처리할 때 종종 필요한 경우가 있습니다. 쉼표로 구분된 값을 여러 행으로 분할합니다. CONNECT BY와 정규 표현식의 조합을 사용하면 이를 달성할 수 있습니다. 단, 쿼리 결과에서 중복되는 행을 피하는 것이 중요합니다.

쉼표로 구분된 값 분할 쿼리

WITH CTE AS (
  SELECT 'a,b,c,d,e' temp, 1 slno FROM DUAL
  UNION
  SELECT 'f,g' temp, 2 slno FROM DUAL
  UNION
  SELECT 'h' temp, 3 slno FROM DUAL
)

SELECT TRIM(REGEXP_SUBSTR(temp, '[^,]+', 1, level)), slno
FROM CTE
CONNECT BY level <= REGEXP_COUNT(temp, '[^,]+')
AND PRIOR slno = slno
AND PRIOR DBMS_RANDOM.VALUE IS NOT NULL

설명

이 쿼리는 재귀적 WITH 절을 사용하여 다음과 같은 이름의 공통 테이블 표현식(CTE)을 생성합니다. CTE. CTE는 쉼표로 구분된 값이 있는 세 개의 데이터 행으로 구성됩니다.

그런 다음 기본 SELECT 문은 임시 열에서 개별 값을 추출합니다. TRIM 함수는 값에서 선행 또는 후행 공백을 제거하는 데 사용됩니다. REGEXP_SUBSTR() 함수는 임시 열을 쉼표 구분 기호를 기준으로 별도의 값으로 분할하는 역할을 합니다.

CONNECT BY 절은 재귀 분할을 수행합니다. 쉼표로 구분된 각 값에 고유한 수준이 할당되도록 합니다. PRIOR slno = slno 조건은 각 행(slno) 내에서만 레벨이 증가하도록 보장합니다.

또한 PRIOR DBMS_RANDOM.VALUE IS NOT NULL 조건은 중복 행이 생성되는 것을 방지하는 데 사용됩니다. DBMS_RANDOM.VALUE는 난수를 반환하는 의사 열입니다. 이를 IS NOT NULL과 비교하여 중복을 제거하는 임의 요소를 도입합니다.

최종 결과는 여러 행이 있는 테이블이며, 각 행은 원래 쉼표로 구분된 문자열의 단일 값을 포함합니다. 이 접근 방식은 중복 행을 생성하지 않고 값을 효과적으로 분할합니다.

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

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