>데이터 베이스 >MySQL 튜토리얼 >Oracle에서 쉼표로 구분된 값을 효율적으로 열로 분할하려면 어떻게 해야 합니까?

Oracle에서 쉼표로 구분된 값을 효율적으로 열로 분할하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-22 09:26:10841검색

How Can I Efficiently Split Comma-Separated Values into Columns in Oracle?

Oracle 데이터베이스: 쉼표로 구분된 값을 효율적으로 열로 구문 분석

이 기사에서는 Oracle에서 자주 발생하는 문제인 쉼표로 구분된 문자열(CSV)에서 개별 값을 고유한 열로 추출하는 문제를 다룹니다. 수많은 값(예: 255)을 수동으로 처리하는 것은 비현실적입니다. 그러나 오라클은 효율적인 솔루션을 제공합니다.

한 가지 효과적인 방법은 REGEXP_SUBSTR 함수를 사용하여 정규식을 사용하여 문자열을 분할하는 것입니다. 정규식의 구조는 정확한 결과를 얻는 데 매우 중요합니다.

다음 데이터를 고려하세요.

<code>ROW | VAL
----------- 
1    | 1.25, 3.87, 2, ... 
2    | 5, 4, 3.3, ....</code>

이러한 값을 개별 열로 분리하려면 다음 REGEXP_SUBSTR 표현식을 사용할 수 있습니다.

<code class="language-sql">regexp_substr('1,2,3,,5,6', '(.*?)(,|$)', 1, 5, NULL, 1)</code>

이 표현의 목적은 다음과 같습니다.

  • 5번째로 나타나는 문자 시퀀스(.)를 0회 이상(*) 찾은 다음 쉼표(,) 또는 문자열 끝($)을 찾습니다.
  • 캡처된 첫 번째 그룹(쉼표나 문자열 끝을 제외한 데이터 자체)을 추출합니다.

이 향상된 표현식은 null 요소를 적절하게 처리하여 후속 값 추출을 방해하지 않도록 방지합니다.

재사용성을 높이기 위해 포럼 토론 https://www.php.cn/link/ae2cd9938873f32a93b6c858bf62f26b에 설명된 것처럼 복잡한 정규 표현식을 사용자 정의 함수 내에 캡슐화할 수 있습니다.

요약하자면, REGEXP_SUBSTR을 잘 만들어진 정규 표현식과 결합하면 null 또는 누락된 값을 처리할 때에도 Oracle에서 쉼표로 구분된 값을 구문 분석하는 안정적인 방법을 제공합니다.

위 내용은 Oracle에서 쉼표로 구분된 값을 효율적으로 열로 분할하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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