Hibernate中的参考列抛出错误

时间:2019-05-13 20:29:20

标签: spring hibernate spring-boot spring-data-jpa

用户实体具有与UserRole实体的OneToMany映射,即1个用户可以具有许多Role ID。 我收到以下错误:-

  

由以下原因引起:org.hibernate.cfg.RecoverableException:找不到   逻辑名称为USER_ID的列   org.hibernate.mapping.Table(t_users)及其相关的超表和   辅助表

@Entity
@Table(name="T_USERS")
public class User {

    @Column(name="ID_COL")
    @Id
    @SequenceGenerator(name="s")
    private Integer userId;

    @Column(name="USER_NAME ")
    private String userName;

    @Column(name="USER_EMAIL")
    private String userEmail;

    @Column(name="PASSWORD")
    private String password;


    @Column(name="IS_ACTIVE")
    private Integer isActive;


    @OneToMany
      @JoinColumns(
                {
                  @JoinColumn(updatable=false,insertable=false, name="ID_COL", referencedColumnName="USER_ID"),
                }
                )
     private List<UserRole> userRole ;

// removed getters n setters for brevity
}

@Entity
@Table(name="T_MAP_USER_ROLES")
public class UserRole {

    @Column(name="MAP_ID")
    @Id
    @SequenceGenerator(name="seq_user_role")
    private Integer mapId;

    @Column(name="USER_ID")
    private Integer userId;

    @Column(name="ROLE_ID ")
    private Integer roleId;

    @Column(name="IS_ACTIVE")
    private Integer isActive;

      @OneToOne
      @JoinColumns(
                {
                  @JoinColumn(updatable=false,insertable=false, name="ROLE_ID", referencedColumnName="ROLE_ID"),
                }
                )
       private Role  role;

问题的原因是什么,如何解决?  UserRole和Role实体之间的映射工作正常

1 个答案:

答案 0 :(得分:0)

@JoinColumns仅用于复合外键。在这种情况下,您只需要@JoinColumn:

@OneToMany @JoinColumn(updatable = false,insertable = false,name =“ ID_COL”)

另外,请注意,单列外键不需要“ referencedColumnName”。