>데이터 베이스 >MySQL 튜토리얼 >질문 답변을 열로 사용하여 MySQL 테이블 데이터를 피벗하는 방법은 무엇입니까?

질문 답변을 열로 사용하여 MySQL 테이블 데이터를 피벗하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-21 19:31:14468검색

How to Pivot MySQL Table Data with Question Answers as Columns?

행으로 표시되는 MySQL 피벗 테이블 열 데이터

피벗 테이블은 열 기반 형식에서 행 기반 형식으로 데이터를 변환하는 강력한 도구입니다. 기반 형식. MySQL에서는 집계 함수와 함께 CASE 표현식을 사용하여 이 변환을 수행할 수 있습니다.

주어진 데이터를 질문 답변이 열로 표시되는 피벗 테이블 형식으로 변환하려면 다음 쿼리를 사용할 수 있습니다.

SELECT  a.ID,
        a.user_ID,
        a.job_id,
        MAX(CASE WHEN c.question = 'Is it this?' THEN b.answer END) 'Is it this?',
        MAX(CASE WHEN c.question = 'Or this?' THEN b.answer END) 'Or this?',
        MAX(CASE WHEN c.question = 'Or that? ' THEN b.answer END) 'Or that? '
FROM    Results a
        INNER JOIN Answers b
            ON a.id = b.fk_result_id
        INNER JOIN Question c
            ON b.fk_question_id = c.ID
GROUP   BY a.ID,
        a.user_ID,
        a.job_id

이 쿼리에서는 CASE 표현식을 사용하여 Question 테이블의 질문 열을 확인하고 Answers 테이블에서 해당 답변을 반환합니다. 그런 다음 집계 함수 MAX를 사용하여 해당 질문에 대해 제공된 답변을 나타내는 각 질문의 최대값을 찾습니다.

동적 피벗

숫자가 질문의 수가 알 수 없거나 크면 다음 코드를 사용하여 동적 SQL 문을 생성할 수 있습니다.

SET @sql = NULL;
SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'MAX(CASE WHEN c.question = ''',
      question,
      ''' then b.answer end) AS ',
      CONCAT('`',question,'`')
    )
  ) INTO @sql
FROM Question;

SET @sql = CONCAT('SELECT  a.ID,
                            a.user_ID,
                            a.job_id, ', @sql, ' 
                    FROM    Results a
                            INNER JOIN Answers b
                                ON a.id = b.fk_result_id
                            INNER JOIN Question c
                                ON b.fk_question_id = c.ID
                    GROUP   BY a.ID,
                            a.user_ID,
                            a.job_id');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

이 코드는 동적 SQL 문을 생성합니다. 다양한 질문을 처리할 수 있는 SQL 문입니다. 각 질문의 최대값을 열 이름으로 연결하여 SELECT 절을 동적으로 구성합니다.

질의 결과는 원하는 형식의 피벗 테이블이 되며, 각 질문 답변은 별도의 열로 표시됩니다. .

위 내용은 질문 답변을 열로 사용하여 MySQL 테이블 데이터를 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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