我正在开发一个项目,我通过添加Hibernate注释来持久保存一些POJO。我遇到的一个问题是像这样的代码失败了,因为Hibernate试图将Time_T
中的子字段映射到同一列(即startTime.sec
和stopTime.sec
都尝试映射colum sec
,导致错误。)
@Entity
public class ExampleClass
{
@Id
long eventId;
Time_T startTime;
Time_T stopTime;
}
@Embeddable
public class Time_T
{
int sec;
int nsec;
}
由于在整个系统中会出现这样的情况,如果有一个选项可以自动为列名添加前缀(例如,将列设为startTime_sec
,startTime_nsec
,那将会很不错,stopTime_sec
,stopTime_nsec
),无需在每个字段的基础上应用替代。 Hibernate是否具备此功能,还是有其他合理的解决方法?
答案 0 :(得分:25)
尝试将属性hibernate.ejb.naming_strategy
设置为org.hibernate.cfg.DefaultComponentSafeNamingStrategy
答案 1 :(得分:10)
在我的情况下使用org.hibernate:hibernate-core:5.0.12.Final和org.springframework.boot:spring-boot-starter-data-jpa:1.5.2.RELEASE我必须在以下属性中执行以下操作:我的application.properties文件:
spring.jpa.hibernate.naming.implicit-strategy=org.hibernate.boot.model.naming.ImplicitNamingStrategyComponentPathImpl
spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
答案 2 :(得分:6)
解决问题的另一种方法是使用@AttributeOverrides和@AttributeOverride注释。在您的示例中,Time_T.sec
属性已映射到sec
列。您可以像这样映射ExampleClass:
@Entity
public class ExampleClass {
@Id
long eventId;
@AttributeOverrides(
@AttributeOverride(name = "sec", column = @Column(name = "start_sec"))
)
Time_T startTime;
Time_T stopTime;
}
结果映射为startTime.sec <=> start_sec
和stopTime.sec <=> sec
。当然,您可以使用注释为stopTipe.sec
列创建更有意义的名称。
答案 3 :(得分:-2)
spring.jpa.hibernate.naming.implicit-strategy = org.hibernate.boot.model.naming.ImplicitNamingStrategyComponentPathImpl spring.jpa.hibernate.naming.physical-strategy = org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl