Hibernate复制插入

时间:2016-05-17 14:23:04

标签: java sql hibernate jsp persistence

解决

但真正的问题不是休眠,主要是我和第二个Netbeans。

我正在发帖,并保存我的数据。但是我在js中发了一个重复的帖子,Netbeans两次都没有解决断点(而且我真的不知道为什么)。所以,对我来说,这是一个帖子,只有一个插入。但不,两个帖子和两个插页。

抱歉失去你的时间:/

我是Hibernate的新手,所以我遇到了一些问题,也许这只是一个愚蠢的问题,我真的不知道。

我尝试使用@ManyToOne关系将对象插入数据库,但是当我持久化并提交事务时,Hibernate会复制它。这是我的代码。

用户发布课程

@Entity
@Table(name = "USERPOST", schema = "ADMIN1")
public class UserPost implements java.io.Serializable {

    private int iduserpost;    
    private String detail;
    private User user;

    public UserPost() {
    }

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "IDUSERPOST", unique = true, nullable = false)
    public int getIduserpost() {
        return this.iduserpost;
    }

    public void setIduserpost(int iduserpost) {
        this.iduserpost = iduserpost;
    }
    @Column(name = "DETAIL", nullable = false)
    public String getDetail() {
        return this.detail;
    }

    public void setDetail(String detail) {
        this.detail = detail;
    }

    @ManyToOne
    @JoinColumn(name = "IDUSER")
    public User getUser() {
        return user;
    }

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

用户类

@Entity
@Table(name = "USER", schema = "ADMIN1")
public class User implements java.io.Serializable {

    private int iduser;
    private String name;
    private String email;
    private Set<UserPost> posts;

    public User() {
    }

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "IDUSER", unique = true, nullable = false)
    public int getIduser() {
        return this.iduser;
    }

    public void setIduser(int iduser) {
        this.iduser = iduser;
    }

    @Column(name = "NAME", nullable = false)
    public String getName() {
        return this.name;
    }

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

    @Column(name = "EMAIL", nullable = false)
    public String getEmail() {
        return this.email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    @OneToMany(mappedBy = "user")
    public Set<UserPost> getPosts() {
        return posts;
    }

    public void setPosts(Set<UserPost> posts) {
        this.posts = posts;
    }

}

在Manager上插入方法

public void Insert(Object data) {
    Session session = null;
    try {
        session = hibernateUtil.getSessionFactory().openSession();
        session.beginTransaction();
        session.persist(data);
        session.getTransaction().commit();
    } catch (Exception e) {
        System.err.println(e.getMessage());
        throw e;
    } finally {
        if (session.isOpen()) {
            session.close();
        }
    }
}

在Servlet上插入

FeedManager manager = new FeedManager();
UserPost post = new UserPost();
post.setDetail(text);
User usrPesist = (User) manager.GetById(User.class, idUser);
post.setUser(usrPesist);
manager.Insert(post);

我得到的结果是将两个UserPosts插入数据库,当我想要的只是一个。

有什么不对吗?

3 个答案:

答案 0 :(得分:0)

由于您已在用户类中定义为private Set<UserPost> posts;, 在equals类中实现hashcodeUserPost方法,这样就可以确保因为它是一个Set而不会添加重复项

但这不是最佳方式。

答案 1 :(得分:0)

我认为这是您的用户类中的ID生成策略的问题。只需尝试在用户类对象中手动设置id即可。

答案 2 :(得分:-1)

尝试使用以下代码更改代码:

@org.hibernate.annotations.Cascade( {org.hibernate.annotations.CascadeType.SAVE_UPDATE})
@OneToMany(mappedBy = "user")
@JoinColumn(name = "IDUSER")
public Set<UserPost> getPosts() {
    return posts;
}