繁体   English   中英

两个实体之间的JPA OneToOne和ManyToMany

[英]JPA OneToOne and ManyToMany between two entities

我早些时候问了一个问题,但认为还不够清楚,我将不进一步阐述代码。
我有一个教师实体和一个部门实体
许多老师属于一个系
一个系有一名系主任。
这是我实现它的方式。

@Entity
public class Teacher extends Model {
@Required
public String surname;

@Required
public String othernames;

    ... 

@OneToOne(mappedBy = "deptHead")
public Department headedBy = new Department();

@ManyToOne(cascade=CascadeType.ALL)
public Department dept = new Department();

... 
}

和部门实体

@Entity
public class Department extends Model {
@Required
public String deptName; 

@OneToMany(mappedBy="dept")
public List<Teacher> teachers = new ArrayList<Teacher>();

@OneToOne
public Teacher deptHead = new Teacher();

    ...

}

我收到以下错误

    @6c4nj8nmg
    Internal Server Error (500) for request GET /

    JPA error
    A JPA error occurred (Unable to build EntityManagerFactory): could not instantiate   test objectmodels.Department

    play.exceptions.JPAException: Unable to build EntityManagerFactory
    at play.db.jpa.JPAPlugin.onApplicationStart(JPAPlugin.java:269)
    at play.plugins.PluginCollection.onApplicationStart(PluginCollection.java:525)
    at play.Play.start(Play.java:526)
    at play.Play.detectChanges(Play.java:630)
    at play.Invoker$Invocation.init(Invoker.java:198)
    at Invocation.HTTP Request(Play!)
    Caused by: org.hibernate.InstantiationException: could not instantiate test objectmodels.Department
    at org.hibernate.engine.UnsavedValueFactory.instantiate(UnsavedValueFactory.java:48)
    at org.hibernate.engine.UnsavedValueFactory.getUnsavedIdentifierValue(UnsavedValueFactory.java:67)
    at org.hibernate.tuple.PropertyFactory.buildIdentifierProperty(PropertyFactory.java:67)
    at org.hibernate.tuple.entity.EntityMetamodel.<init>(EntityMetamodel.java:135)
    at org.hibernate.persister.entity.AbstractEntityPersister.<init>(AbstractEntityPersister.java:485)
    at org.hibernate.persister.entity.SingleTableEntityPersister.<init>(SingleTableEntityPersister.java:133)
    at org.hibernate.persister.PersisterFactory.createClassPersister(PersisterFactory.java:84)
    at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:286)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1872)
    at org.hibernate.ejb.Ejb3Configuration.buildEntityManagerFactory(Ejb3Configuration.java:906)
    at play.db.jpa.JPAPlugin.onApplicationStart(JPAPlugin.java:267)
    ... 5 more
    Caused by: java.lang.reflect.InvocationTargetException
    at  org.hibernate.engine.UnsavedValueFactory.instantiate(UnsavedValueFactory.java:45)
    ... 15 more
     Caused by: java.lang.StackOverflowError
    at java.lang.Class.searchMethods(Unknown Source)
    at java.lang.Class.getMethod0(Unknown Source)
    at java.lang.Class.getMethod(Unknown Source)
    at      play.classloading.enhancers.PropertiesEnhancer$FieldAccessor.invokeWriteProperty(PropertiesEnhancer.java:268)
    at models.Department.<init>(Department.java:23)
    at models.Teacher.<init>(Teacher.java:47)
    at models.Department.<init>(Department.java:26)
    ...

在这些方面需要帮助

这不是JPA问题,而是由Teacher / Department递归实例化引起的。

当您创建或要求JPA创建Teacher的实例时, Teacher尝试实例化Department ,实例化Teacher ...到无穷大。

因此,您会在该堆栈跟踪的结尾附近看到一个StackOverflowError错误。

从类定义中删除= new Teacher()= new Department()表达式; 创建它们时,请依赖并使用适当的setter方法。

我删除了Teacher和Department之间的@oneToOne关系,并创建了一个名为DepartmentHeads的新实体,现在一切正常。
这是结果。

@Entity
public class Teacher extends Model {
    @Required
    public String surname;

    @Required
    public String othernames;

    ... 

    @ManyToOne(cascade=CascadeType.ALL)
    public Department dept = new Department();

    ... 
}

@Entity
public class Department extends Model {
    @Required
    public String deptName; 

    @OneToMany(mappedBy="dept")
    public List<Teacher> teachers = new ArrayList<Teacher>();

    ...

}

@Entity
public class DepartmentHead extends Model{
    @OneToOne
    public Teacher teacher = new Teacher();

    @OneToOne
    public Department dept = new Department();  
}

现在一切正常。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM