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 중국어 웹사이트의 기타 관련 기사를 참조하세요!