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.PhysicalNamingStrategyStandardImpl,您可以有效地覆盖默认命名行为并确保遵循带注释的列名称。
以上是为什么我的列注释在 Spring Boot JPA 中被忽略?的详细内容。更多信息请关注PHP中文网其他相关文章!