Spring Boot JPA での列アノテーションのオーバーライドについて
人気の ORM フレームワークである Spring Boot JPA を使用すると、開発者はエンティティに @Column アノテーションを付けることができます。データベース内の特定の列名を指定します。ただし、特定のシナリオでは、JPA が @Column アノテーションを無視し、データベース スキーマ内のプロパティ名のアンダースコア付きバージョンがデフォルトになることが確認されています。
JPA が列のアノテーションを無視する理由
JPA が @Column アノテーションを無視する理由の 1 つは、基礎となる Hibernate フレームワークで使用されている命名戦略である可能性があります。デフォルトでは、Hibernate は @Column アノテーションに関係なく Snake Case 列名を生成する org.hibernate.cfg. ImprovementNamingStrategy 戦略を使用します。
解決策: EJB3 命名戦略
この問題を解決し、JPA が @Column アノテーションを尊重するようにするには、Hibernate 命名戦略を org.hibernate.cfg.EJB3NamingStrategy に明示的に設定します。この戦略では、@Column アノテーションで指定された大文字と小文字の間隔と文字間隔が保持されます。
SQL Server の方言に関する考慮事項
Microsoft SQL Server に接続している場合、次のような問題が発生する可能性があります。 Hibernate が org.hibernate.dialect.SQLServerDialect 方言を使用する場合の別の問題。この方言は、EJB3 命名戦略を使用している場合でも、JPA が大文字と小文字が混合した列名を使用する可能性がある、命名の不一致を引き起こす可能性があります。
従来の暗黙的および物理的な命名戦略
に対処するにはこの問題を解決するには、次のプロパティを application.properties ファイルに追加できます。
<code class="properties">spring.jpa.hibernate.naming.implicit-strategy=org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyJpaImpl spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl</code>
これらの設定により、Hibernate はレガシーの暗黙的および標準の物理的な名前付け戦略を使用するようになります。これにより、@Column アノテーションが確実に使用されます。尊重され、列名は一貫して生成されます。
以上がJPA が Spring Boot で @Column アノテーションを無視することがあるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。