>데이터 베이스 >MySQL 튜토리얼 >SQL에서 쉼표로 구분된 행을 분할하는 방법은 무엇입니까?

SQL에서 쉼표로 구분된 행을 분할하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-14 09:25:43357검색

How to Split Comma-Separated Rows in SQL?

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

SQL에서는 쉼표로 구분된 값이 포함된 열을 개별 행으로 분할해야 하는 시나리오가 발생할 수 있습니다. 이는 순수 SQL 쿼리나 외부 도구를 포함한 다양한 기술을 통해 달성할 수 있습니다.

순수 SQL에서 쉼표로 구분된 행을 분할하는 효율적인 방법은 SUBSTRING_INDEX()CROSS JOIN 함수를 조합하여 사용하는 것입니다. SUBSTRING_INDEX() 함수는 지정된 구분 기호와 위치를 기반으로 주어진 문자열에서 하위 문자열을 추출합니다. CROSS JOIN 함수는 서로 다른 테이블의 여러 행을 곱하여 데카르트 곱을 생성합니다.

이러한 함수를 사용하면 일련의 숫자를 생성하고 반복할 수 있습니다. 각 숫자에 대해 SUBSTRING_INDEX() 함수를 사용하여 소스 열에서 원하는 쉼표로 구분된 값을 추출할 수 있습니다. 샘플 쿼리는 다음과 같습니다.

<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>

이 쿼리는 1부터 100까지의 숫자 시퀀스를 생성하고 이를 반복하여 각 소스 행에서 쉼표로 구분된 값을 추출합니다. SUBSTRING_INDEX() 함수는 시퀀스에서 숫자의 위치를 ​​기준으로 원하는 값을 추출하는 데 사용됩니다. WHERE 절은 기존 쉼표로 구분된 값만 추출되도록 보장하여 범위를 벗어난 오류를 방지합니다.

또는 영구 개수 테이블을 사용하여 숫자 시퀀스를 생성하고 쿼리를 단순화할 수 있습니다. 결과 쿼리는 위의 쿼리와 유사하지만 하위 쿼리는 카운트 테이블에 대한 참조로 대체됩니다.

이러한 기술을 함께 사용하면 복잡한 쿼리나 외부 도구 없이도 SQL에서 쉼표로 구분된 행을 분할할 수 있습니다. 방법 선택은 애플리케이션의 특정 요구 사항과 성능 고려 사항에 따라 달라집니다.

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

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