MySQL 동적 행-열 작업
질문:
정확한 열 수를 미리 알 수 없는 경우에도 여러 테이블에서 데이터를 검색하고 동적 열 헤더가 있는 피벗 테이블로 형식을 지정합니다.
원래 쿼리:
<code class="language-sql">SELECT partners.name, products.name, COUNT(*) FROM sales JOIN products ON sales.products_id = products.id JOIN partners ON sales.partners_id = partners.id GROUP BY sales.partners_id, sales.products_id LIMIT 0, 30</code>
CASE 문을 사용한 풀이:
MySQL에는 PIVOT 함수가 없으므로 CASE 문과 함께 집계 함수를 사용해야 합니다.
<code class="language-sql">select pt.partner_name, count(case when pd.product_name = 'Product A' THEN 1 END) as ProductA, count(case when pd.product_name = 'Product B' THEN 1 END) as ProductB, count(case when pd.product_name = 'Product C' THEN 1 END) as ProductC, count(case when pd.product_name = 'Product D' THEN 1 END) as ProductD, count(case when pd.product_name = 'Product E' THEN 1 END) as ProductE from partners pt left join sales s on pt.part_id = s.partner_id left join products pd on s.product_id = pd.prod_id group by pt.partner_name</code>
준비된 문을 사용한 동적 피벗 테이블:
동적 열 헤더를 처리하려면 준비된 문을 사용할 수 있습니다.
<code class="language-sql">SET @sql = NULL; SELECT GROUP_CONCAT(DISTINCT CONCAT( 'count(case when Product_Name = ''', Product_Name, ''' then 1 end) AS ', replace(Product_Name, ' ', '') ) ) INTO @sql from products; SET @sql = CONCAT('SELECT pt.partner_name, ', @sql, ' from partners pt left join sales s on pt.part_id = s.partner_id left join products pd on s.product_id = pd.prod_id group by pt.partner_name'); PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt;</code>
위 내용은 MySQL 행을 열로 동적으로 피벗하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!