ホームページ >データベース >mysql チュートリアル >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 サイトの他の関連記事を参照してください。