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

MySQL データを動的な列ヘッダーを持つ単一の行にピボットする方法?

Susan Sarandon
Susan Sarandonオリジナル
2025-01-06 09:51:40461ブラウズ

How to Pivot MySQL Data into a Single Row with Dynamic Column Headers?

MySQL PIVOT/CROSSTAB QUERY

問題 1: 単一行のデータの取得

PIVOT 関数を使用できますデータを単一行形式に変換します。次のクエリは、これを達成するための以前の試みを変更します。

SELECT 
  app_id,
  transaction_id,
  mobile_no,
  MAX(CASE WHEN node_id = 1 THEN entered_value END) AS Q1,
  MAX(CASE WHEN node_id = 2 THEN entered_value END) AS Q2,
  MAX(CASE WHEN node_id = 3 THEN entered_value END) AS Q3,
  MAX(CASE WHEN node_id = 4 THEN entered_value END) AS Q4,
  MAX(CASE WHEN node_id = 5 THEN entered_value END) AS Q5
FROM trn_user_log
GROUP BY app_id, transaction_id, mobile_no;

このクエリは、app_id、transaction_id、mobile_no ごとに行をグループ化し、MAX 関数を使用して、対応する各 node_id 列に入力された最大値を取得します。

問題 2: 列の値をヘッダーとして使用するNames

customer_attribute 列の値をヘッダー名として使用するには、CASE ステートメントを AS キーワードと組み合わせて使用​​します。変更されたクエリは次のとおりです。

SELECT 
  app_id,
  transaction_id,
  mobile_no,
  MAX(CASE WHEN node_id = 1 THEN entered_value END) AS CASE customer_attribute WHEN 'Q1' THEN entered_value END,
  MAX(CASE WHEN node_id = 2 THEN entered_value END) AS CASE customer_attribute WHEN 'Q2' THEN entered_value END,
  MAX(CASE WHEN node_id = 3 THEN entered_value END) AS CASE customer_attribute WHEN 'Q3' THEN entered_value END,
  MAX(CASE WHEN node_id = 4 THEN entered_value END) AS CASE customer_attribute WHEN 'Q4' THEN entered_value END,
  MAX(CASE WHEN node_id = 5 THEN entered_value END) AS CASE customer_attribute WHEN 'Q5' THEN entered_value END
FROM trn_user_log
GROUP BY app_id, transaction_id, mobile_no;

このクエリでは、MAX 関数内で CASE ステートメントが使用され、一致する customer_attribute 値に基づいて enter_value が選択されます。 AS キーワードは、一致する customer_attribute 値を列ヘッダーとして割り当てます。

以上がMySQL データを動的な列ヘッダーを持つ単一の行にピボットする方法?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。