>데이터 베이스 >MySQL 튜토리얼 >동적으로 생성된 열이 있는 SQL 테이블을 전치하는 방법은 무엇입니까?

동적으로 생성된 열이 있는 SQL 테이블을 전치하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-05 05:03:41573검색

How to Transpose a SQL Table with Dynamically Generated Columns?

SQL 테이블 전치: 유연한 데이터 변환 달성

SQL의 전치 작업에는 행을 열로 또는 그 반대로 변환하는 작업이 포함됩니다. 이러한 맥락에서 사용자별 데이터에 대해 사용자 정의 필드 이름으로 테이블을 바꾸는 문제를 해결해 보겠습니다.

문제:

사용자가 다음과 같은 테이블이 있다고 가정합니다. 정의된 필드 이름과 해당 값을 사용하여 각 사용자의 데이터가 필드를 나타내는 열 이름과 함께 단일 행에 표시되는 형식으로 바꾸는 것이 목표입니다. 이름.

예:

입력 테이블:

Id UserId FieldName FieldValue
1 100 Username John Doe
2 100 Password pass123!
3 102 Username Jane
4 102 Password $ecret
5 102 Email Address [email protected]

원하는 출력:

UserId Username Password Email Address
100 John Doe pass123! NULL
102 Jane $ecret [email protected]

솔루션 MySQL에서(ANSI 없이 구문):

MySQL은 ANSI PIVOT/UNPIVOT 구문을 지원하지 않으므로 조건부 집계 접근 방식을 사용할 수 있습니다.

SELECT t.userid,
       MAX(CASE WHEN t.fieldname = 'Username' THEN t.fieldvalue ELSE NULL END) AS Username,
       MAX(CASE WHEN t.fieldname = 'Password' THEN t.fieldvalue ELSE NULL END) AS Password,
       MAX(CASE WHEN t.fieldname = 'Email Address' THEN t.fieldvalue ELSE NULL END) AS Email
FROM TABLE t
GROUP BY t.userid

이 접근 방식은 각 행을 반복하고 CASE 문을 사용합니다. 필드 이름을 기반으로 원하는 출력 열에 값을 할당합니다. 그런 다음 각 userId에 대한 결과를 집계합니다.

Prepared 문을 사용하는 동적 솔루션:

솔루션을 더욱 다양하게 만들기 위해 MySQL의 준비된 문 구문을 사용할 수 있습니다. 필드를 동적으로 지정하려면:

SET @query = "SELECT userid, ";
SET @enum_query = "";
SELECT CONCAT(@enum_query, "MAX(CASE WHEN fieldname = '", fieldname, "' THEN fieldvalue ELSE NULL END) AS ", fieldname,", ")
INTO @enum_query
FROM (
    SELECT DISTINCT fieldname
    FROM TABLE
) AS subquery;
SET @enum_query = SUBSTRING(@enum_query, 1, LENGTH(@enum_query) - 2);
SET @query = CONCAT(@query, @enum_query, " FROM TABLE GROUP BY userid;");
PREPARE stmt FROM @query;
EXECUTE stmt;

이 접근 방식은 원하는 필드 이름을 모두 포함하는 동적 쿼리를 생성합니다. 출력의 열입니다.

위 내용은 동적으로 생성된 열이 있는 SQL 테이블을 전치하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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