집 >데이터 베이스 >MySQL 튜토리얼 >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>
이 표현의 목적은 다음과 같습니다.
.
)를 0회 이상(*
) 찾은 다음 쉼표(,
) 또는 문자열 끝($
)을 찾습니다.이 향상된 표현식은 null 요소를 적절하게 처리하여 후속 값 추출을 방해하지 않도록 방지합니다.
재사용성을 높이기 위해 포럼 토론 https://www.php.cn/link/ae2cd9938873f32a93b6c858bf62f26b에 설명된 것처럼 복잡한 정규 표현식을 사용자 정의 함수 내에 캡슐화할 수 있습니다.
요약하자면, REGEXP_SUBSTR
을 잘 만들어진 정규 표현식과 결합하면 null 또는 누락된 값을 처리할 때에도 Oracle에서 쉼표로 구분된 값을 구문 분석하는 안정적인 방법을 제공합니다.
위 내용은 Oracle에서 쉼표로 구분된 값을 효율적으로 열로 분할하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!