了解Spring Boot JPA 中的列註釋重寫
Spring Boot JPA 是一種流行的ORM 框架,允許開發人員使用@ Column 對實體進行註解指定資料庫中的特定欄位名稱。但是,據觀察,在某些情況下,JPA 可能會忽略 @Column 註釋,並預設使用資料庫架構中下劃線大小寫的屬性名稱版本。
為什麼 JPA 可能會忽略列註解
JPA 忽略 @Column 註解的一個可能原因可能是底層 Hibernate 框架使用的命名策略。預設情況下,Hibernate 使用 org.hibernate.cfg.ImprovedNamingStrategy 策略,該策略會產生 Snake Case 列名稱,而不管 @Column 註解如何。
解決方案:EJB3 命名策略
要解決此問題並確保JPA 遵循@Column 註釋,您可以將Hibernate 命名策略明確設定為org.hibernate. cfg.EJB3NamingStrategy。此策略將保留 @Column 註解中指定的大小寫和字元間距。
SQL Server 方言注意事項
如果您連接到Microsoft SQL Server,您可能會遇到Hibernate 使用org.hibernate.dialect.SQLServerDialect 方言的另一個問題。這種方言可能會導致命名不一致,其中 JPA 可能會使用混合大小寫的列名稱,即使使用 EJB3 命名策略也是如此。
舊版隱式和實體命名策略
要解決對於這個問題,您可以將以下屬性新增至您的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中文網其他相關文章!