주어진 데이터를 피벗 테이블 형식으로 변환하려면 질문 답변이 열로 표시되는 다음 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