解决
但真正的问题不是休眠,主要是我和第二个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插入数据库,当我想要的只是一个。
有什么不对吗?
答案 0 :(得分:0)
由于您已在用户类中定义为private Set<UserPost> posts;
,
在equals
类中实现hashcode
和UserPost
方法,这样就可以确保因为它是一个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;
}