3

我收到错误:调用 init 方法失败;嵌套异常是 org.hibernate.MappingException:实体映射中的重复列:com.messagemanager.domain.User 列:id(应使用 insert="false" update="false" 进行映射)

有我的实体:

@MappedSuperclass
public abstract class BaseEntity{

    @Id
    @Column(nullable = false, unique = true, name = "id", insertable = false, updatable = false)
    @GeneratedValue(strategy= GenerationType.AUTO)
    private Long id;

    public Long getId() {
        return id;
    }   

    public void setId(Long id) {
        this.id = id;
    }
}


@Entity
@Table(name = "User")
public class User  extends BaseEntity implements Serializable{
    @Column(name = UserFieldsKey.ID, length = 50, nullable = false)
    private String name;

    @Column(updatable = false, insertable = false)
    @Transient
    private List<Message> listMessage = new ArrayList<>();

    public static class UserFieldsKey{
        public static final String NAME = "name";
    }

    public User() {
    }

    @OneToMany(fetch = FetchType.EAGER, mappedBy = "user")
    public List<Message> getListMessage() {
        return listMessage;
    }

    public void setListMessage(List<Message> listMessage) {
        this.listMessage = listMessage;
    }


    public String getName() {
        return name;
    }

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


@Entity
@Table(name = "Message")
public class Message extends BaseEntity implements Serializable{
    @Column(name = MessageFieldsKey.MESSAGE, length = 500, nullable = false)
    private String message;

    @ManyToOne(cascade=CascadeType.ALL, fetch = FetchType.EAGER)
    @JoinColumn(name="user")
    private User user;

    @Column(name = "id_user")
    private Long id_user;

    public Long getId_user() {
        return id_user;
    }

    public void setId_user(Long id_user) {
        this.id_user = id_user;
    }

    public static class MessageFieldsKey{
        public static final String MESSAGE = "mes";
    }

    public String getMessage() {
        return message;
    }

    public User getUser() {
        return user;
    }

    public Message() {
    }

    public Message(String message, User user) {
        this.message = message;
        this.user = user;
    }

    public void setMessage(String message) {
        this.message = message;
    }

    public void setUser(User user) {
        this.user = user;
    }
}

有任何想法吗?

PS非常感谢!

4

2 回答 2

0

看起来那是因为你有这个:

@ManyToOne(cascade=CascadeType.ALL, fetch = FetchType.EAGER)
@JoinColumn(name="user")
private User user;

这将映射到User.id;并且Message你已经有了一个,id因为你正在扩展BaseEntity

于 2017-04-05T12:29:30.933 回答
0

问题已解决)我误解了表之间的关系。

于 2017-04-13T14:08:38.403 回答