Ошибка в составном ключе в Hibernate org.hibernate.MappingException: не удалось определить тип для: java.util.Set,

Друзья, у меня возникла проблема с составным ключом Hibernate. Ошибка: org.hibernate.MappingException: не удалось определить тип для: java.util.Set, в таблице: IDP_UserManagerMapping, для столбцов: [org.hibernate.mapping.Column(idps)]. У меня есть Пробовал с @transient и другими вещами, но неэффективно. Пожалуйста, помогите.

public class IDPUserManagerMapping implements Serializable {
    private Long id;
    private Users user;
    private Users manager;
    private Users assessor;

    @OneToMany(fetch = FetchType.LAZY)
    @JoinColumns({
        @JoinColumn(name="user_id" ,referencedColumnName = "user_id"),
        @JoinColumn(name="manager_id" ,referencedColumnName = "manager_id")
        ,@JoinColumn(name="assessor_id" ,referencedColumnName = "assessor_id")
    })
    @Cascade(CascadeType.ALL)
    private Set<IDPMaster> idps = null;

    @Id
    @SequenceGenerator(sequenceName="idp_usermanagermapping_id_seq",name="idp_usermanagermapping_id_seq_gen")
    @GeneratedValue(generator="idp_usermanagermapping_id_seq_gen")
    @Column(name="id",nullable=false,unique=true,updatable=false)
    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }

    public Set<IDPMaster> getIdps() {
        return idps;
    }
    public void setIdps(Set<IDPMaster> idps) {
        this.idps = idps;
    }
        @ManyToOne(fetch=FetchType.LAZY)
    @JoinColumn(name="user_id",nullable=false)
    public Users getUser() {
        return user;
    }
    public void setUser(Users user) {
        this.user = user;
    }

    @ManyToOne(fetch=FetchType.LAZY)
    @JoinColumn(name="manager_id",nullable=false)
    public Users getManager() {
        return manager;
    }
    public void setManager(Users manager) {
        this.manager = manager;
    }

    @ManyToOne(fetch=FetchType.LAZY)
    @JoinColumn(name="assessor_id")
    public Users getAssessor() {
        return assessor;
    }
    public void setAssessor(Users assessor) {
        this.assessor = assessor;
    }
    }

Второй объект

public class IDPMaster implements Serializable {
    private Long id;
    private Users managerUser;
    private Users assessorUser;
    private Users idpUsers;
    @Id
    @SequenceGenerator(name="idp_master_id_seq_gen",sequenceName="idp_master_id_seq")
    @GeneratedValue(generator="idp_master_id_seq_gen")
    @Column(name="id",nullable=false,unique=true)
    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }
    @ManyToOne(fetch=FetchType.LAZY)
    @JoinColumn(name="user_id",nullable=false)
    public Users getIdpUsers() {
        return idpUsers;
    }
    public void setIdpUsers(Users idpUsers) {
        this.idpUsers = idpUsers;
    }
    @OneToOne(fetch=FetchType.LAZY)
    @JoinColumn(name="manager_id")
    public Users getManagerUser() {
        return managerUser;
    }
    public void setManagerUser(Users managerUser) {
        this.managerUser = managerUser;
    }

    @OneToOne(fetch=FetchType.LAZY)
    @JoinColumn(name="assessor_id")
    public Users getAssessorUser() {
        return assessorUser;
    }
    public void setAssessorUser(Users assessorUser) {
        this.assessorUser = assessorUser;
    }
    }

person ThinkTank    schedule 06.07.2017    source источник


Ответы (1)


Вы должны переместить аннотации

@OneToMany(fetch = FetchType.LAZY)
    @JoinColumns({
        @JoinColumn(name="user_id" ,referencedColumnName = "user_id"),
        @JoinColumn(name="manager_id" ,referencedColumnName = "manager_id")
        ,@JoinColumn(name="assessor_id" ,referencedColumnName = "assessor_id")
    })
    @Cascade(CascadeType.ALL)

от private Set<IDPMaster> idps = null; до public Set<IDPMaster> getIdps() добытчика

Hibernate анализирует аннотации по столбцу ID, и если вы используете аннотации для геттера, вы должны использовать аннотации геттера везде.

person Mike Adamenko    schedule 06.07.2017
comment
Но это временные члены, поэтому я оставил их в поле. Если я сделаю то же самое, я должен пометить это аннотацией @Transient. Так будет ли это работать здесь? - person ThinkTank; 07.07.2017