Spring Boot JPA で見落とされる列名の注釈: 不一致について
JPA を使用した Spring Boot アプリケーションでは、開発者は次のような興味深い問題に遭遇する可能性があります。カスタム名の列注釈は無視されるため、SQL はデフォルトの規則に従って列名を生成します。この記事では、この見落としの背後にある理由を詳しく掘り下げ、実行可能な解決策を提供します。
JPA の Hibernate で使用される標準の命名戦略は DefaultNamingStrategy であり、さまざまな変換ルールを使用してエンティティ名と列名を SQL にマップします。ただし、この戦略では列の注釈が明示的に考慮されない可能性があり、その結果、注釈付きの名前 (「TestName」) の代わりにデフォルトの列名 (この場合は「test_name」) が生成されます。
この矛盾に対処するには、 Hibernate の命名戦略を明示的に構成する必要があります。アプリケーションのプロパティで spring.jpa.hibernate.naming_strategy=org.hibernate.cfg.EJB3NamingStrategy を設定すると、Hibernate は EJB3NamingStrategy に切り替わります。この戦略では列の注釈名が保持され、元の問題が解決されます。
ただし、この構成は普遍的に適用できるわけではありません。特定のシナリオでは、基礎となる Hibernate 方言も命名規則に影響を与える可能性があります。たとえば、Microsoft SQL Server 2014 Express に接続する場合、Hibernate はデフォルトで SQLServerDialect を使用します。この方言は、明示的に構成されている場合でも、必要な命名戦略を完全にサポートしていない可能性があります。
この制限を克服するために、Hibernate 5 では追加の構成オプションが提供されています。
これらの両方のプロパティをそれぞれ org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyJpaImpl および org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl に設定することで、効果的にオーバーライドできます。デフォルトの命名動作を変更し、注釈が付けられた列名が尊重されるようにします。
以上がSpring Boot JPA で列の注釈が無視されるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。