ホームページ > データベース > mysql チュートリアル > MySQL の行を列に動的にピボットする方法

MySQL の行を列に動的にピボットする方法

Mary-Kate Olsen
リリース: 2025-01-25 13:12:16
オリジナル
770 人が閲覧しました

How to Dynamically Pivot MySQL Rows into Columns?

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 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート