MySQL을 사용하여 동적 행 값을 열 이름으로 변환
고정 구조의 기존 테이블에서는 피벗 형식으로 데이터를 가져오는 것이 어려울 수 있습니다. MySQL에는 기본 피벗 기능이 없으며 이 문제를 해결하려면 준비된 명령문을 사용해야 합니다.
다음 레거시 테이블을 고려하세요.
<code>id name value ------------------------------ 0 timezone Europe/London 0 language en 0 country 45 0 something x 1 timezone Europe/Paris 1 language fr 1 country 46</code>
동적 행 값을 열 이름으로 사용하여 원하는 출력:
<code>id timezone language country something --------------------------------------------------- 0 Europe/London en 45 x 1 Europe/Paris fr 46</code>
다른 RDBMS와 달리 MySQL에는 간접적인 방법이 필요합니다. 준비된 문을 작성하는 것이 선호되는 접근 방식입니다.
<code class="language-sql">SELECT CONCAT( 'SELECT `table`.id', GROUP_CONCAT(' , `t_', REPLACE(name, '`', '``'), '`.value AS `', REPLACE(name, '`', '``'), '`' SEPARATOR ''), ' FROM `table` ', GROUP_CONCAT(' LEFT JOIN `table` AS `t_', REPLACE(name, '`', '``'), '` ON `table`.id = `t_', REPLACE(name, '`', '``'), '`.id AND `t_', REPLACE(name, '`', '``'), '`.name = ', QUOTE(name) SEPARATOR ''), ' GROUP BY `table`.id' ) INTO @qry FROM (SELECT DISTINCT name FROM `table`) t; PREPARE stmt FROM @qry; EXECUTE stmt;</code>
이 쿼리는 GROUP_CONCAT()
을 사용하여 필요한 JOIN과 열 별칭을 연결하는 동적 SQL 문을 작성합니다. 그런 다음 생성된 SQL 문이 준비되고 실행됩니다.
이 접근 방식을 사용하면 하드 코딩된 하위 선택이나 CASE 문 없이 고유한 행 값을 변수 열 이름으로 사용할 수 있습니다. 더 많은 설정이 필요할 수 있지만 MySQL에서 데이터를 회전하는 데 더 유연하고 효율적인 솔루션을 제공합니다.
위 내용은 MySQL에서 동적 행 값을 열 이름으로 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!