집 >데이터 베이스 >MySQL 튜토리얼 >SQL에서 쉼표로 구분된 값을 별도의 행으로 분할하려면 어떻게 해야 합니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!