>데이터 베이스 >MySQL 튜토리얼 >SQL에서 쉼표로 구분된 값을 별도의 행으로 분할하려면 어떻게 해야 합니까?

SQL에서 쉼표로 구분된 값을 별도의 행으로 분할하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-14 09:55:42397검색

How Can I Split Comma-Separated Values in SQL into Separate Rows?

SQL에서 쉼표로 구분된 행 값 분할

데이터베이스 관리를 하다 보면 쉼표로 구분된 값(CSV)으로 저장된 데이터를 접하는 경우가 많습니다. 그러나 일부 분석 또는 보고 목적으로 이러한 CSV를 별도의 행으로 분할할 수 있습니다. 이 문서에서는 이 분할 작업을 수행하는 SQL 기반 접근 방식을 살펴보겠습니다.

해결 방법은 MySQL에서 SUBSTRING_INDEX() 함수를 활용하는 것입니다. 이 함수를 사용하면 구분 문자를 기반으로 지정된 문자열에서 하위 문자열을 추출할 수 있습니다. 또한 카운트 테이블과의 교차 조인을 사용하여 CSV 분할을 위한 행 인덱스로 사용되는 일련의 숫자를 생성합니다.

다음은 SQL 쿼리입니다.

<code class="language-sql">SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(t.values, ',', n.n), ',', -1) value
FROM table1 t CROSS JOIN 
(
   SELECT a.N + b.N * 10 + 1 n
     FROM 
    (SELECT 0 AS N UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9) a
   ,(SELECT 0 AS N UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 5 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9) b
    ORDER BY n
) n
WHERE n.n <= LENGTH(t.values) - LENGTH(REPLACE(t.values, ',', '')) + 1;</code>

이 쿼리는 table1 테이블에 있는 values 열의 CSV 값을 효과적으로 분할하고 각 값에 대해 새 행을 생성합니다. 카운트 테이블을 사용하면 단일 행에서 여러 값을 분할할 수 있습니다.

예제 데이터 및 출력:

table1 테이블에서 다음 데이터를 고려하세요.

values
somethingA,somethingB,somethingC
somethingElseA, somethingElseB

이 데이터에 쿼리를 적용하면 다음과 같은 출력이 생성됩니다.

value
somethingA
somethingB
somethingC
somethingElseA
somethingElseB

이 기술을 활용하면 CSV 형식으로 저장된 데이터를 개별 행으로 편리하게 분할하여 추가 분석이나 처리가 가능합니다.

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

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