了解 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中文网其他相关文章!