집 >데이터 베이스 >MySQL 튜토리얼 >MySQL에서 쉼표로 구분된 값을 개별 행으로 분할하는 방법은 무엇입니까?
SQL에서 쉼표로 구분된 행 분할
질문:
SQL(MySQL)에서 쉼표로 구분된 값이 포함된 열을 별도의 행으로 분할하는 방법은 무엇입니까?
정답:
MySQL은 쉼표로 구분된 행 값을 분할하는 내장 함수를 제공하지 않습니다. 그러나 숫자 계산과 MySQL의 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>
이 쿼리는 SUBSTRING_INDEX() 함수를 사용하여 구분 기호로 쉼표를 지정하고 분할 위치로 n 값을 지정하여 개별 값을 추출합니다. 카운트 숫자는 1부터 100까지의 숫자 범위를 생성하는 하위 쿼리를 사용하여 생성되므로 행당 최대 100개의 분리된 값을 분할할 수 있습니다.
영구 개수 테이블 방법의 경우 다음 쿼리를 사용합니다.
<code class="language-sql">SELECT SUBSTRING_INDEX(SUBSTRING_INDEX(t.values, ',', n.n), ',', -1) value FROM table1 t CROSS JOIN tally n WHERE n.n <= LENGTH(t.values) - LENGTH(REPLACE(t.values, ',', '')) + 1;</code>
쉼표로 구분된 값이 포함된 많은 수의 행을 분할해야 하는 경우 이 방법은 확장성이 더 좋습니다.
위 내용은 MySQL에서 쉼표로 구분된 값을 개별 행으로 분할하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!