Vee*_*Arr 30 java orm hibernate
我正在开发一个项目,我通过添加Hibernate注释来持久保存一些POJO.有一个问题我运行到是像这样的代码失败,因为Hibernate的尝试中的子字段映射Time_T到同一列(即startTime.sec和stopTime.sec都试图映射到科拉姆sec,导致错误).
@Entity
public class ExampleClass
{
@Id
long eventId;
Time_T startTime;
Time_T stopTime;
}
@Embeddable
public class Time_T
{
int sec;
int nsec;
}
Run Code Online (Sandbox Code Playgroud)
由于会有很多出现这样在整个系统中,这将是很好,如果有自动追加的前缀列的名称(例如使列是一个选项startTime_sec,startTime_nsec,stopTime_sec,stopTime_nsec),而不必基于每个应用覆盖现场基础.Hibernate是否具备此功能,还是有其他合理的解决方法?
Boz*_*zho 27
尝试将属性设置hibernate.ejb.naming_strategy为org.hibernate.cfg.DefaultComponentSafeNamingStrategy
Far*_*jmi 11
在我的情况下使用org.hibernate:hibernate-core:5.0.12.Final和org.springframework.boot:spring-boot-starter-data-jpa:1.5.2.RELEASE我必须在我的应用程序中执行以下属性.属性文件:
spring.jpa.hibernate.naming.implicit-strategy=org.hibernate.boot.model.naming.ImplicitNamingStrategyComponentPathImpl
spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
Run Code Online (Sandbox Code Playgroud)
解决该问题的另一种方法是使用@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;
}
Run Code Online (Sandbox Code Playgroud)
结果映射是startTime.sec <=> start_sec和stopTime.sec <=> sec.当然,您可以使用注释为stopTipe.sec列创建更有意义的名称.
| 归档时间: |
|
| 查看次数: |
9755 次 |
| 最近记录: |