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

MySQL에서 쉼표로 구분된 값을 개별 행으로 분할하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-14 11:25:43533검색

How to Split Comma-Separated Values in MySQL into Individual Rows?

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

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