下面是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>();
这种情况有什么解决办法吗?
parentPK.java
@Embeddable
public class ParentPk implements Serializable {
@Column(name="COL_1")
private String col1;
@Column(ame="COL_2")
private String col2;
}
@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>();
}
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)
java转换为@embedbable,扩展了parentpk.java
<class name="SomeOwnerClassDetail" table="FOO_DETAIL">
<composite-id class="ChildPk"
name="childPk">
<key-property name="col1" column="COL_1" type="java.lang.Long"/>
<key-property name="col2" column="COL_2" length="32"/>
<key-property name="col3" column="COL_3" length="3"/>
</composite-id>
</class>
在上面,映射col1和col2是从parentpk.java继承来的,如果在xml映射中的某个ownerclass.java中使用ChildPk作为外键,但在带注释的映射中不能使用,则可以访问它们。
我不能改变我的类的结构,因为它是遗留应用程序。
<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>
您可以实现@embeddable
类之间的继承。您只需用@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
。
问题内容: 我有班钱是@Embeddable 当我在实体中多次使用它时,一切正常。例如 上面的代码完美地工作。 现在,当我有另一个@Embeddable想要在其中包含Money实例并且该@Embeddable被实体多次使用时,就会出现问题。例: 可嵌入 public class ReportCostValues implements Serializable { 实体 public class R
在Grails中,当子类可以属于父类中的两个属性之一(但不能同时属于两个属性)时,我很难理解Belongsto-HasMany关系的概念。 例如: 其中Person位于Store.Employees列表或Store.Managers列表中 事先谢谢....
我们必须在可选元素“mappedby”中指定什么。是特定模型的table_name还是classname? 哪个是正确的? 这个
问题内容: 我正在学习Java,并且希望将自己的课堂变成可观察的课堂。 但是我已经有了它扩展了另一个类。 我该怎么办? 问题答案: 我建议避免完全使用该类,而应 定义事件特定的侦听器和相应的事件定义 。然后在您的类中定义一个侦听器列表,以及添加和删除侦听器以及向其传播事件的方法(请参见下文)。 强制您使用它来表示事件,然后使用来检查事件类型,这是一种丑陋的非OO方法,并使代码更难以理解。如果查看j
<![CDATA[插入MEMBER_SERVICE_RECORD(MEMBER_ID,SERVICE_DATE,service_milees,SERVICE_DESC,MODIFIED_DATE)值(?,?,?,?,?)]]>
问题内容: 我有一个正在创建Hibernate映射的类,该类包含一个无法修改的旧对象,因此它没有必要的id字段来与Hibernate完美配合。我想将旧对象注释为新类的@Embedded字段,并为旧对象编写hbm.xml文件,并注意它是可嵌入的。有没有办法做到这一点?我见过的唯一的嵌入对象的文档指的是对对象进行注释,而不是使用XML。 我意识到我可以扩展旧对象并对其进行适当的注释,但是这些情况可能经