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

mappedBy引用未知的目标实体属性-hibernate错误

宋安晏
2023-03-14

首先,我的课程:

使用者

package com.patpuc.model;

import java.util.List;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import com.patpuc.model.RolesMap;

@Entity
@Table(name = "users")
public class User {
    @Id
    @Column(name = "USER_ID", unique = true, nullable = false)
    private int user_id;
    @Column(name = "NAME", nullable = false)
    private String name;
    @Column(name = "SURNAME", unique = true, nullable = false)
    private String surname;
    @Column(name = "USERNAME_U", unique = true, nullable = false)
    private String username_u; // zamiast username
    @Column(name = "PASSWORD", unique = true, nullable = false)
    private String password;
    @Column(name = "USER_DESCRIPTION", nullable = false)
    private String userDescription;
    @Column(name = "AUTHORITY", nullable = false)
    private String authority = "ROLE_USER";
    @Column(name = "ENABLED", nullable = false)
    private int enabled;

    @OneToMany(mappedBy = "rUser")
    private List<RolesMap> rolesMap;

    public List<RolesMap> getRolesMap() {
        return rolesMap;
    }

    public void setRolesMap(List<RolesMap> rolesMap) {
        this.rolesMap = rolesMap;
    }

    /**
     * @return the user_id
     */
    public int getUser_id() {
        return user_id;
    }

    /**
     * @param user_id
     *            the user_id to set
     */
    public void setUser_id(int user_id) {
        this.user_id = user_id;
    }

    /**
     * @return the name
     */
    public String getName() {
        return name;
    }

    /**
     * @param name
     *            the name to set
     */
    public void setName(String name) {
        this.name = name;
    }

    /**
     * @return the surname
     */
    public String getSurname() {
        return surname;
    }

    /**
     * @param surname
     *            the surname to set
     */
    public void setSurname(String surname) {
        this.surname = surname;
    }

    /**
     * @return the username_u
     */
    public String getUsername_u() {
        return username_u;
    }

    /**
     * @param username_u
     *            the username_u to set
     */
    public void setUsername_u(String username_u) {
        this.username_u = username_u;
    }

    /**
     * @return the password
     */
    public String getPassword() {
        return password;
    }

    /**
     * @param password
     *            the password to set
     */
    public void setPassword(String password) {
        this.password = password;
    }

    /**
     * @return the userDescription
     */
    public String getUserDescription() {
        return userDescription;
    }

    /**
     * @param userDescription
     *            the userDescription to set
     */
    public void setUserDescription(String userDescription) {
        this.userDescription = userDescription;
    }

    /**
     * @return the authority
     */
    public String getAuthority() {
        return authority;
    }

    /**
     * @param authority
     *            the authority to set
     */
    public void setAuthority(String authority) {
        this.authority = authority;
    }

    /**
     * @return the enabled
     */
    public int getEnabled() {
        return enabled;
    }

    /**
     * @param enabled
     *            the enabled to set
     */
    public void setEnabled(int enabled) {
        this.enabled = enabled;
    }

    @Override
    public String toString() {
        StringBuffer strBuff = new StringBuffer();
        strBuff.append("id : ").append(getUser_id());
        strBuff.append(", name : ").append(getName());
        strBuff.append(", surname : ").append(getSurname());
        return strBuff.toString();
    }
}

角色地图。JAVA

package com.patpuc.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
import com.patpuc.model.User;

@Entity
@Table(name = "roles_map")
public class RolesMap {
    private int rm_id;
    private String username_a;
    private String username_l;
    //private String username_u;
    private String password;
    private int role_id;

    @ManyToOne
    @JoinColumn(name="username_u", nullable=false)
    private User rUser;
   public RolesMap(){

    }
    /**
     * @return the user
     */
    public User getUser() {
        return rUser;
    }
    /**
     * @param user the user to set
     */
    public void setUser(User rUser) {
        this.rUser = rUser;
    }


    @Id
    @Column(name = "RM_ID", unique = true, nullable = false)
    public int getRmId() {
        return rm_id;
    }
    public void setRmId(int rm_id) {
        this.rm_id = rm_id;
    }

    @Column(name = "USERNAME_A", unique = true)
    public String getUsernameA() {
        return username_a;
    }
    public void setUsernameA(String username_a) {
        this.username_a = username_a;
    }

    @Column(name = "USERNAME_L", unique = true)
    public String getUsernameL() {
        return username_l;
    }
    public void setUsernameL(String username_l) {
        this.username_l = username_l;
    }



    @Column(name = "PASSWORD", unique = true, nullable = false)
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }

    @Column(name = "ROLE_ID", unique = true, nullable = false)
    public int getRoleId() {
        return role_id;
    }
    public void setRoleId(int role_id) {
        this.role_id = role_id;
    }

}

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

但我不知道我做错了什么。谁能帮我解决这个问题吗?

共有1个答案

王弘和
2023-03-14

默认情况下,定义实体时,可以使用基于字段的访问或基于属性的访问,但不能同时使用这两种访问。“访问类型”基本上是指您的JPA提供商希望确定实体状态的位置。如果使用字段访问,它会查看实例变量。如果使用了属性访问,它会查看getter。

在您的例子中,您没有明确定义访问类型,所以JPA试图通过查看您放置注释的位置来找出它。我认为Hibernate是根据@Id注释的位置来决定的。由于您的@Id注释被放置在一个getter上,所以Hibernate对角色映射使用基于属性的访问。

使用基于属性的访问,您没有名为rUser的属性,因为您没有名为getRUser()的getter。

该规范规定,不应将注释的放置方式混为一谈:

实体层次结构中访问类型以这种方式默认的所有此类类在字段或属性上的注释位置必须一致,以便在层次结构中应用单一的、一致的默认访问类型

一致地放置注释,这样就不会有歧义(例如,总是将注释放在html" target="_blank">实例变量上)。这将导致对RoffMap的以下更改:

@Entity
@Table(name = "roles_map")
public class RolesMap {
    @Id
    @Column(name = "RM_ID", unique = true, nullable = false)
    private int rm_id;
    @Column(name = "USERNAME_A", unique = true)
    private String username_a;
    @Column(name = "USERNAME_L", unique = true)
    private String username_l;
    @Column(name = "PASSWORD", unique = true, nullable = false)
    private String password;
    @Column(name = "ROLE_ID", unique = true, nullable = false)
    private int role_id;
    @ManyToOne
    @JoinColumn(name="username_u", nullable=false)
    private User rUser;

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

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

  • 我正在做一个测试项目来学习Hibernate,不幸的是,我得到了这个错误,并查看了其他类似的错误,但是遵循它们并没有解决我的问题。我仍然得到这个错误。 如果有人能检查出哪里出了问题,我真的很想知道我的错误是什么。 我的模型类: } 这是第二个模型类: } 这是我的主要: 这是我的hibernate util类: 公共类HibernateUtil{私有静态最终会议工厂会议工厂=构建会议工厂(); }

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

  • 我试图通过从域对象创建表来测试一对多映射,但我看到错误mappedBy引用未知的目标实体属性。谁能看一下吗? 谢谢 hibernate.cfg.xml 错误StackTrace 谢谢你的回复。我做了您提到的更改,还做了一些其他更改,比如向main.java添加session.save(flightvenive)和insertable=false,updatable=false以及@JoinColu

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