Spring Boot JPA 中被忽略的列名註解:了解差異
在使用JPA 的Spring Boot 應用程式中,開發人員可能會遇到一個奇怪的問題:具有自訂名稱的列註解將被忽略,導致SQL 按照預設約定產生列名稱。本文深入探討了這種疏忽背後的原因,並提供了可行的解決方案。
Hibernate 在 JPA 中使用的標準命名策略是 DefaultNamingStrategy,它使用各種轉換規則將實體和列名稱對應到 SQL。但是,此策略可能不會明確考慮列註釋,從而導致產生預設列名稱(在本例中為“test_name”)而不是帶有註釋的名稱(“TestName”)。
為了解決此差異,有必要明確配置 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.PhysicalNaStandardStrategyImpl 和org.hibernate.boot.model.naming.PhysicalNaStandardStrategyImpl 和org.hibernate.boot.model.naming.PhysicalNaStandardStrategygyImpl並確保遵循帶註釋的列名稱。
以上是為什麼我的列註解在 Spring Boot JPA 中被忽略?的詳細內容。更多資訊請關注PHP中文網其他相關文章!