JPA アノテーションを使用した MySQL AUTO_INCREMENT フィールドの注釈
自動インクリメント カラムを持つ JPA エンティティを保存するときに発生する一般的な問題は、無効なカラムの指定です。 ID生成戦略。この特定のケースでは、問題は MySQL データベースの AUTO_INCREMENT 列にあります。
この問題を解決するには、ID フィールドを定義するときに適切な戦略を使用することが不可欠です。 MySQL の場合、戦略は IDENTITY に設定する必要があります:
@Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id;
このアプローチは、特定のタイプを指定せずに AUTO 戦略を使用するのと同じです:
@Id @GeneratedValue(strategy = GenerationType.AUTO) private Long id;
ただし、明示的に設定することをお勧めします。戦略を IDENTITY に設定します。これにより、生成された SQL 挿入で期待どおりに id 列が省略されます。
提供されているコード サンプルでは、マッピングは技術的には正しいです。ただし、適切な互換性を確保するには、MySQL ダイアレクトが Hibernate 構成で指定されていることを確認することが重要です。さらに、データベース テーブルの作成と Java コードの不一致が問題の原因となっている可能性があります。
これらの要因に対処することで、問題を解決し、自動インクリメント カラムを持つエンティティを MySQL に正しく保存できるようになります。データベース。
以上がJPA を使用して MySQL AUTO_INCREMENT フィールドに適切に注釈を付ける方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。