"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 질문 답변으로 MySQL 테이블 데이터를 피벗하는 방법은 무엇입니까?

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

2025-03-23에 게시되었습니다
검색:564

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

주어진 데이터를 피벗 테이블 형식으로 변환하려면 질문 답변이 열로 표시되는 다음 Query를 사용할 수 있습니다. a.user_id, a.job_id, MAX (C.Question = '이거야?' max (c.question = '또는 this?'그런 다음 b.answer end) '또는 this?', max (c.question = '또는 that?'the b.answer end) '또는 그게? ' 결과에서 a 내부 가입 답변 b a.id = b.fk_result_id 내부 조인 질문 c b.fk_question_id = c.id A.Id, 그룹 a.user_id, a.job_id

이 쿼리에서 케이스 표현식은 질문 테이블의 질문 열을 확인하고 해당 답변을 답변 테이블에서 반환하는 데 사용됩니다. Aggregation Function Max는 각 질문에 대한 최대 값을 찾는 데 사용됩니다.이 질문에 대한 답변을 나타냅니다.

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

다음 코드를 사용하여 생성 될 수 있습니다. 선택하다 group_concat (구별 동의 ( 'MAX (C.Question =' '', 질문, '' '그런 다음 b.answer end) as', CONCAT ( '`' ', Question,' '') )) ) @SQL로 질문에서; set @sql = concat ( 'select a.id, a.user_id, a.job_id, ', @sql,' 결과에서 a 내부 가입 답변 b a.id = b.fk_result_id 내부 조인 질문 c b.fk_question_id = c.id A.Id, 그룹 a.user_id, a.job_id '); @SQL에서 STMT 준비; STMT 실행; DealLocate 준비 STMT;

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

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3