>데이터 베이스 >MySQL 튜토리얼 >MySQL의 집계된 문자열에서 개별 값을 추출하기 위해 GROUP_CONCAT을 어떻게 되돌릴 수 있습니까?

MySQL의 집계된 문자열에서 개별 값을 추출하기 위해 GROUP_CONCAT을 어떻게 되돌릴 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-17 07:24:25852검색

How Can I Reverse GROUP_CONCAT to Extract Individual Values from Aggregated Strings in MySQL?

GROUP_CONCAT 풀기: 집계된 데이터에서 개별 값 추출

데이터베이스 관리 영역에서 GROUP_CONCAT 함수는 여러 데이터를 집계하는 강력한 도구입니다. 값을 쉼표로 구분된 단일 문자열로 변환합니다. 그러나 이러한 집계된 문자열을 개별 구성 요소로 분해하는 반대 과제에 직면하는 경우가 있을 수 있습니다.

문제의 본질

다음 데이터를 고려하세요. "colors"라는 테이블:

| id | colors               |
|----+----------------------|
| 1  | Red,Green,Blue       |
| 2  | Orangered,Periwinkle |

이 데이터를 각 색상이 포함된 구조로 변환하는 것이 목표입니다. 별도의 행으로 표시:

| id | colors     |
|----+------------|
| 1  | Red        |
| 1  | Green      |
| 1  | Blue       |
| 2  | Orangered  |
| 2  | Periwinkle |

해결책: 문자열 풀기

MySQL은 이 작업을 수행하기 위한 여러 기술을 제공합니다. 한 가지 접근 방식은 다음과 같이 SUBSTRING_INDEX 및 SUBSTRING 함수를 활용합니다.

SELECT
  id,
  SUBSTRING_INDEX(SUBSTRING_INDEX(colors, ',', n.digit+1), ',', -1) color
FROM
  colors
  INNER JOIN
  (SELECT 0 digit UNION ALL SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3) n
  ON LENGTH(REPLACE(colors, ',' , '')) <= LENGTH(colors)-n.digit
ORDER BY
  id,
  n.digit

이 쿼리는 다음과 같이 작동합니다.

  1. SUBSTRING_INDEX를 사용하여 쉼표 내 각 색상의 시작 및 끝 위치를 찾습니다. 구분된 문자열.
  2. 색상에 해당하는 숫자를 생성하는 테이블과 결합 위치.
  3. 조인된 테이블의 색상 개수 범위를 초과하는 행을 필터링합니다.
  4. ID 및 색상 위치별로 결과를 정렬합니다.

공개 수수께끼: 역집계 또는 Un-GROUP_CONCAT

위에서 설명한 작업을 흔히 "역집계" 또는 "un-GROUP_CONCAT"이라고 합니다. 이전에 집계되거나 연결된 데이터에서 개별 값을 추출하고 번들 해제할 수 있습니다. 이 기술은 집계 자체가 아닌 개별 데이터 포인트에 대한 추가 분석이나 변환을 수행해야 할 때 특히 유용합니다.

위 내용은 MySQL의 집계된 문자열에서 개별 값을 추출하기 위해 GROUP_CONCAT을 어떻게 되돌릴 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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