Hibernate@Embeddeble类,它扩展了另一个@Embeddeble类,未找到@OneToMany映射的属性

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

我们正在将旧的基于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.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
有外来关系,并且倾向于使用属性col1col2,这些属性在
ChildPk.java
的父类中可用,但当执行查询时,hibernate不会找到col1col2,而不是我复制父类的
ChildPk.java
中的col1col2一切正常

下面是
SomeOwnerClass.java
的代码片段,它指的是col1col2

>  @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的支持