ホームページ >データベース >mysql チュートリアル >MySQL でデータをアンピボットおよびピボットして列を行に変換する方法
MySQL データ ピボットとピボット: 列を行に変換
複数の列 (col1、col2、col3 など) を含むテーブルがあり、それをピボット テーブル形式に変換して、列ではなく行単位でデータを表示したいとします。
MySQL でこれを実現するには、まず UNION ALL
クエリを使用してデータをピボットします。このプロセスでは、元の列の値から複数の行が作成されます:
<code class="language-sql">SELECT id, month, col1 AS value, 'col1' AS descrip FROM yourtable UNION ALL SELECT id, month, col2 AS value, 'col2' AS descrip FROM yourtable UNION ALL SELECT id, month, col3 AS value, 'col3' AS descrip FROM yourtable UNION ALL SELECT id, month, col4 AS value, 'col4' AS descrip FROM yourtable;</code>
UNION ALL
クエリ結果:
ID | MONTH | VALUE | DESCRIP |
---|---|---|---|
101 | Jan | A | col1 |
102 | feb | C | col1 |
101 | Jan | B | col2 |
102 | feb | A | col2 |
101 | Jan | (null) | col3 |
102 | feb | G | col3 |
101 | Jan | B | col4 |
102 | feb | E | col4 |
次に、UNION ALL
クエリをサブクエリでラップしてデータをピボットします。集約関数 GROUP BY
および CASE
ステートメントを使用して、ピボットされていないパースペクティブの構造を目的のパースペクティブ形式に変換します。
<code class="language-sql">SELECT descrip, MAX(CASE WHEN month = 'jan' THEN value ELSE 0 END) AS jan, MAX(CASE WHEN month = 'feb' THEN value ELSE 0 END) AS feb FROM ( SELECT id, month, col1 AS value, 'col1' AS descrip FROM yourtable UNION ALL SELECT id, month, col2 AS value, 'col2' AS descrip FROM yourtable UNION ALL SELECT id, month, col3 AS value, 'col3' AS descrip FROM yourtable UNION ALL SELECT id, month, col4 AS value, 'col4' AS descrip FROM yourtable ) AS src GROUP BY descrip;</code>ピボットクエリの結果:
DESCRIP | JAN | FEB |
---|---|---|
col1 | A | C |
col2 | B | A |
col3 | 0 | G |
col4 | B | E |
以上がMySQL でデータをアンピボットおよびピボットして列を行に変換する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。