ホームページ >データベース >mysql チュートリアル >MySQL で整数列名を持つ動的ピボット テーブルを作成する方法

MySQL で整数列名を持つ動的ピボット テーブルを作成する方法

DDD
DDDオリジナル
2024-11-15 08:40:02488ブラウズ

How to Create Dynamic Pivot Tables with Integer Column Names in MySQL?

MySQL の動的ピボット テーブル

動的列を含むピボット テーブルを生成しようとする場合、列名が正しく処理されました。指定された状況では、user_id は整数であるため、適切にフォーマットされていないと問題が発生する可能性があります。

これに対処するには、user_id 値をバックティック (`) で囲んで列名として指定する必要があります。数値として誤って解釈されるのを防ぎます。変更されたクエリは次のとおりです。

SET @sql = NULL;
SELECT
  GROUP_CONCAT(DISTINCT
    CONCAT(
      'max(case when user_id = ''',
      user_id,
      ''' then score end) AS `',
      user_id, '`'
    )
  ) INTO @sql
FROM  measure2;

SET @sql = CONCAT('SELECT inspection_date, ', @sql, ' 
                  FROM measure2 
                  GROUP BY inspection_date');

PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

この変更により、user_id 値が列名として扱われるようになり、一意の user_id とそれに対応するスコアを表す動的列を含むピボット テーブルが作成されます。

以上がMySQL で整数列名を持つ動的ピボット テーブルを作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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