首页  >  文章  >  Java  >  为什么我的列注释在 Spring Boot JPA 中被忽略?

为什么我的列注释在 Spring Boot JPA 中被忽略?

Barbara Streisand
Barbara Streisand原创
2024-10-31 02:12:011003浏览

Why Are My Column Annotations Ignored in Spring Boot   JPA?

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 提供了额外的配置选项:

  • spring.jpa.hibernate.naming .implicit-strategy:确定生成隐式列名称(例如外键列)的策略。
  • spring.jpa.hibernate.naming.physical-strategy:控制基于生成物理列和表名称的策略实体和属性名称。

通过将这两个属性分别设置为 org.hibernate.boot.model.naming.ImplicitNamingStrategyLegacyJpaImpl 和 org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl,您可以有效地覆盖默认命名行为并确保遵循带注释的列名称。

以上是为什么我的列注释在 Spring Boot JPA 中被忽略?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn