当前位置: 首页 > 知识库问答 >
问题:

在应用程序启动时获取mappedBy引用未知目标实体属性异常

简滨海
2023-03-14

我有两个实体,其中一个我正在使用一个用户输入的PK。

我在启动springboot应用程序时遇到以下异常。

我的实体类如下所示。

import java.util.HashSet;
import java.util.Set;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.Table;

@Entity
@Table(name="EMPLOYEE")
public class Employee {

    @Id
    @Column(name="NAME")
    private String name;

    @Column(name="PHONE_NUMBER")
    private String phoneNumber;

    @OneToMany(mappedBy = "employee")
    private Set<Department> departments = new HashSet<Department>();

    public Employee(String name, String phoneNumber, Set<Department> department) {
        super();
        this.name = name;
        this.phoneNumber = phoneNumber;
        this.departments = department;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPhoneNumber() {
        return phoneNumber;
    }

    public void setPhoneNumber(String phoneNumber) {
        this.phoneNumber = phoneNumber;
    }

    public Set<Department> getDepartment() {
        return departments;
    }

    public void setDepartment(Set<Department> department) {
        this.departments = department;
    }

    //equals and hashcode methods overriden



}


import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQuery;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;

@Entity
@Table(name="DEPARTMENT")
public class Department {

    @Id
    @Column(name="ID")
    @SequenceGenerator(name="seq",sequenceName="dept_seq", allocationSize=1)
    @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="seq")
    private Long deptId;

    @Column(name="DEPT_NAME")
    private String deptName;

    @Column(name="DEPT_BOSS")
    private String deptBoss;

    @ManyToOne
    @JoinColumn(name = "NAME", nullable = false)
    private Employee employee;


    public Department(Long deptId, String deptName, String deptBoss, Employee employee) {
        super();
        this.deptName = deptName;
        this.deptBoss = deptBoss;
        this.employee = employee;
    }

    public Long getDeptId() {
        return deptId;
    }

    public void setDeptId(Long deptId) {
        this.deptId = deptId;
    }

    public String getDeptName() {
        return deptName;
    }

    public void setDeptName(String deptName) {
        this.deptName = deptName;
    }

    public String getDeptBoss() {
        return deptBoss;
    }

    public void setDeptBoss(String deptBoss) {
        this.deptBoss = deptBoss;
    }

    public Employee getEmployee() {
        return employee;
    }

    public void setEmployee(Employee employee) {
        this.employee = employee;
    }


    //OVERRIDE EQUALS AND HASHCODE

}

我无法弄清楚代码中的问题。

共有1个答案

宋望
2023-03-14

AFAIK Hibernate需要每个实体的无参数构造函数。由于employeedepartment都定义了显式构造函数,因此也必须定义no-arg构造函数

 类似资料:
  • 您好,我是JPA Spring boot的新手,现在我正在尝试将两个表之间的连接转换为第三个表。所以我有一个医生和病人表,其中有它的属性,一个医生可以检查每个病人,一个病人可以看望每个医生。但是在一次检查中,不能有超过一个病人和一个医生。对于医生,我想保留他们检查过的患者的信息,分别是患者的信息,以及他们检查过的医生的信息。我想创建一个名为DoctorVisit的中间表,其中我有做检查的医生的id

  • 我第一次使用Hibernate,并且很难让它与我的模式一起工作。 我得到了"org.hibernate.注释异常:映射通过引用未知的目标实体属性:学生。教师在Faculty.all学生”。 一些学生共用一个导师。因此,我认为学生和教师的关系是多对多的,但我被告知这是多对多的关系。 Student.java Faculty.java 数据库架构: 在看了留档后,我尝试了几种不同的注释,但我看不出我做

  • 我有几个从db动态创建的实体类,但是当我用关系注释它们时,我有以下错误 组织。冬眠AnnotationException:mappedBy引用未知的目标实体属性:coma。实体impl。能力标准实施。昏迷中的能力。实体impl。胜任力impl。能力标准执行 我的实体类如下 和 我对冬眠感到困惑和绝望。。。

  • 首先,我的课程: 使用者 角色地图。JAVA 当我尝试在服务器上运行这个我有这样的异常:错误创建bean与名称'SessionFactory'定义在ServletContext资源[/WEB-INF/类/base Beans.xml]:调用init方法失败;嵌套的异常org.hibernate.注释异常:映射通过引用一个未知的目标实体属性:com.patpuc.model.ap.users在com

  • 我对Meal和MealGroup之间的关系有问题。Hibernate返回给我:"mappdBy引用未知的目标实体属性"。我有两个实体: 我尝试删除@Join Column和mappedBy。已创建其他表,但我想加入该列。 和 谢谢你的帮助。

  • 我正试图用hibernate在数据库中存储一个实体。我有以下课程: 实验节点组如下所示: NodeGroup类看起来像这样: 现在,当我尝试编译代码时,我得到了这个错误: 导致原因:org.hibernate.AnnotationException:mappedBy引用未知的目标实体属性:[……]。在[…]中进行实验nodegroup.experience。UsableRemoteExperien