Hibernate@Embeddeble类,它扩展了另一个@Embeddeble类,未找到@OneToMany映射的属性
我们正在将旧的基于xml的配置转换为基于注释的配置 形势Hibernate@Embeddeble类,它扩展了另一个@Embeddeble类,未找到@OneToMany映射的属性,hibernate,inheritance,extends,embeddable,Hibernate,Inheritance,Extends,Embeddable,我们正在将旧的基于xml的配置转换为基于注释的配置 形势 org.hibernate.MappingException: Unable to find column with logical name: COL_1 in SomeOwnerClass at org.hibernate.cfg.Ejb3JoinColumn.checkReferencedColumnsType(Ejb3JoinColumn.java:587) at org.hibernate.cfg.BinderH
org.hibernate.MappingException: Unable to find column with logical name: COL_1 in SomeOwnerClass
at org.hibernate.cfg.Ejb3JoinColumn.checkReferencedColumnsType(Ejb3JoinColumn.java:587)
at org.hibernate.cfg.BinderHelper.createSyntheticPropertyReference(BinderHelper.java:258)
at org.hibernate.cfg.annotations.CollectionBinder.bindCollectionSecondPass(CollectionBinder.java:1451)
at org.hibernate.cfg.annotations.CollectionBinder.bindOneToManySecondPass(CollectionBinder.java:864)
at org.hibernate.cfg.annotations.CollectionBinder.bindStarToManySecondPass(CollectionBinder.java:779)
at org.hibernate.cfg.annotations.CollectionBinder$1.secondPass(CollectionBinder.java:728)
at org.hibernate.cfg.CollectionSecondPass.doSecondPass(CollectionSecondPass.java:70)
at org.hibernate.cfg.Configuration.originalSecondPassCompile(Configuration.java:1695)
at org.hibernate.cfg.Configuration.secondPassCompile(Configuration.java:1424)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1844)
at com.foo.mypackage.ParentHibernateUtil.initiateSessionFactory(ParentHibernateUtil.java:112)
at com.foo.mypackage.ParentHibernateUtil.getSessionFactory(ParentHibernateUtil.java:131)
at com.foo.mypackage.GenericHibernateDAO.getSession(GenericHibernateDAO.java:36)
at com.foo.mypackage.GenericHibernateDAO.beginTransaction(GenericHibernateDAO.java:63)
at com.foo.mypackage.MarsTest.main(MyTest.java:22)
有一个类被注释为@embeddeble(ParentPk.java)
,另一个类扩展了这个类@embeddeble(ChildPk.java)
,这个ChildPk.java在SomeOwnerClass.java
中用作复合主键,与另一个类SomeChildTable.java
有外来关系,并且倾向于使用属性col1和col2,这些属性在ChildPk.java
的父类中可用,但当执行查询时,hibernate不会找到col1和col2,而不是我复制父类的ChildPk.java
中的col1和col2一切正常
下面是SomeOwnerClass.java
的代码片段,它指的是col1和col2
> @OneToMany(orphanRemoval = true, fetch=FetchType.EAGER)
> @Cascade(value = {CascadeType.ALL,CascadeType.SAVE_UPDATE})
> @Fetch(FetchMode.JOIN)
> @JoinColumns({
> @JoinColumn(name="COL_1",insertable=false,updatable=false,referencedColumnName="COL_1"),
> @JoinColumn(name="COL_2",insertable=false,updatable=false,referencedColumnName="COL_2"),
> @JoinColumn(name="COL_3",insertable=false,updatable=false,referencedColumnName="COL_3"),
> }) private Set<SomeChildTable> collection = new
> HashSet<SomeChildTable>();
ChildPk.java
@Embeddable
public class ChildPk extends ParentPk implements Serializable {
@Column(name="COL_3")
private String col3;
}
@Entity
@Table(name="FOO")
public class SomeOwnerClass implements Serializable {
@EmbeddedId
@AttributeOverrides({@AttributeOverride(name="col1", column=@Column(name="COL_1",length=38))})
private ChildPk childPk = new ChildPk();
@OneToMany(orphanRemoval = true, fetch=FetchType.EAGER)
@Cascade(value = {CascadeType.ALL,CascadeType.SAVE_UPDATE})
@Fetch(FetchMode.JOIN)
@JoinColumns({
@JoinColumn(name="COL_1",insertable=false,updatable=false,referencedColumnName="COL_1"),
@JoinColumn(name="COL_2",insertable=false,updatable=false,referencedColumnName="COL_2"),
@JoinColumn(name="COL_3",insertable=false,updatable=false,referencedColumnName="COL_3"),
})
private Set<SomeChildTable> collection = new HashSet<SomeChildTable>();
}
<set name="someDetailKey" cascade="all,delete-orphan,save-update" lazy="false" fetch="join" >
<key foreign-key="FOO_Foreign_Key" >
<column name="COL_1"/>
<column name="COL_2"/>
<column name="COL_3"/>
</key>
<one-to-many class="ChildPk" />
</set>
SomeOwnerClass.java
@Embeddable
public class ChildPk extends ParentPk implements Serializable {
@Column(name="COL_3")
private String col3;
}
@Entity
@Table(name="FOO")
public class SomeOwnerClass implements Serializable {
@EmbeddedId
@AttributeOverrides({@AttributeOverride(name="col1", column=@Column(name="COL_1",length=38))})
private ChildPk childPk = new ChildPk();
@OneToMany(orphanRemoval = true, fetch=FetchType.EAGER)
@Cascade(value = {CascadeType.ALL,CascadeType.SAVE_UPDATE})
@Fetch(FetchMode.JOIN)
@JoinColumns({
@JoinColumn(name="COL_1",insertable=false,updatable=false,referencedColumnName="COL_1"),
@JoinColumn(name="COL_2",insertable=false,updatable=false,referencedColumnName="COL_2"),
@JoinColumn(name="COL_3",insertable=false,updatable=false,referencedColumnName="COL_3"),
})
private Set<SomeChildTable> collection = new HashSet<SomeChildTable>();
}
<set name="someDetailKey" cascade="all,delete-orphan,save-update" lazy="false" fetch="join" >
<key foreign-key="FOO_Foreign_Key" >
<column name="COL_1"/>
<column name="COL_2"/>
<column name="COL_3"/>
</key>
<one-to-many class="ChildPk" />
</set>
附加细节
我已经尝试将基于xml的配置映射到基于注释的配置,下面是旧的基于xml的配置,它在继承方面工作得很好
ChildPk.java转换为@Embedable,扩展了ParentPk.java
在上面的映射中,col1和col2继承自ParentPk.java,如果ChildPk在xml映射中用作SomeOwnerClass.java中的外键,而不是在带注释的映射中,则可以访问ParentPk.java
我无法更改类的结构,因为它是遗留应用程序。
SomeOwnerClass.java
@Embeddable
public class ChildPk extends ParentPk implements Serializable {
@Column(name="COL_3")
private String col3;
}
@Entity
@Table(name="FOO")
public class SomeOwnerClass implements Serializable {
@EmbeddedId
@AttributeOverrides({@AttributeOverride(name="col1", column=@Column(name="COL_1",length=38))})
private ChildPk childPk = new ChildPk();
@OneToMany(orphanRemoval = true, fetch=FetchType.EAGER)
@Cascade(value = {CascadeType.ALL,CascadeType.SAVE_UPDATE})
@Fetch(FetchMode.JOIN)
@JoinColumns({
@JoinColumn(name="COL_1",insertable=false,updatable=false,referencedColumnName="COL_1"),
@JoinColumn(name="COL_2",insertable=false,updatable=false,referencedColumnName="COL_2"),
@JoinColumn(name="COL_3",insertable=false,updatable=false,referencedColumnName="COL_3"),
})
private Set<SomeChildTable> collection = new HashSet<SomeChildTable>();
}
<set name="someDetailKey" cascade="all,delete-orphan,save-update" lazy="false" fetch="join" >
<key foreign-key="FOO_Foreign_Key" >
<column name="COL_1"/>
<column name="COL_2"/>
<column name="COL_3"/>
</key>
<one-to-many class="ChildPk" />
</set>
Hibernate不支持继承
@embeddeble
组件:
不能直接持久化或查询可嵌入对象,只能在其父对象的上下文中持久化或查询该对象。可嵌入对象没有id或表。JPA规范不支持具有继承性的可嵌入对象,尽管某些JPA提供程序可能允许这样做
-
JPA规范不支持具有继承性的可嵌入对象因此,您不能在
@embeddeble
中使用继承
您可以尝试将父id作为子id的属性来完成此操作。您可以在
@embeddeble
类之间实现继承。您只需使用@MappedSuperclass
注释父类即可
因此,例如:
@Embeddable
@MappedSuperclass
public class Parent {
@Basic
private String parentProperty;
// ... getters/setters
}
@Embeddable
public class Child extends Parent {
@Basic
private String childProperty;
// ... getters/setters
}
这样,Hibernate(用5.x测试)将在
Child
类中正确映射parentProperty
和childProperty
。谢谢您的回复,但相同的类关系在基于xml的配置中工作良好我需要它的替代注释。我添加了额外的细节“额外的细节”+1,因为这是一个有效的答案,如果它意味着不应该(通常)为这个可用的注释这个答案是不正确的。正如我在下面对答案的评论中提到的,Hibernate实际上“支持@Embeddeble的继承”。这是正确的答案。JPA没有明确定义对嵌入式继承的支持。但是,Hibernate不支持继承EmbeddedableShit enter而不是上面的shift+enter:(这是正确的答案。JPA没有明确定义对可嵌入文件继承的支持。但是Hibernate确实支持使用@MappedSuperclass
来定义其超类型的可嵌入文件继承。在WILFFY 15中,我们应该添加对扩展另一个可嵌入文件-wokrs的支持