gpt4 book ai didi

java - 在 H2 中持久化 ManyToMany 实体会引发异常

转载 作者:行者123 更新时间:2023-11-30 06:11:05 24 4
gpt4 key购买 nike

我有 2 个实体,除其他外,它们都有彼此的列表。

“帖子”类:

@ManyToMany(mappedBy = "posts", cascade=CascadeType.ALL)
private List<Tag> tags;

“标签”类:

@ManyToMany(cascade = CascadeType.ALL)
@JoinTable
private List<Post> posts;`

在数据库中,我有“POSTS”表、“TAGS”表和“TAGS_POSTS”用于多对多关系。数据库中的结构和数据库中的表都很好。但是当我开始在 Posts 表中保留 Post entiti 时,发生了错误。

这是向数据库添加新帖子的代码,相同的代码适用于其他实体,甚至对于也具有多对多关系的“标​​签”。

private EntityManagerFactory emf;

@PersistenceUnit
public void setEmf(EntityManagerFactory emf) {
this.emf = emf;
}

public Post add(Post post) {
EntityManager em = emf.createEntityManager();
em.getTransaction().begin();
em.persist(post);
em.getTransaction().commit();
return post;
}

现在在应用程序开始时,我尝试使用一些虚拟数据填充数据库以进行测试。除了 Post 之外,具有相同代码的所有其他实体都工作正常。

这里是代码(我尝试不设置标签属性,将其设置为空ArrayList,并将其设置为数据库中已存在标签的列表,结果是相同的):

 ApplicationContext ac =  SpringApplication.run(PostsPortalApplication.class, args);


PostsService ps = (PostsService) ac.getBean("postsService");

Post post = new Post();
post.setId(j);
post.setDate(new Date());
post.setDescription("desc" + "/" );
post.setDislikes(5);
post.setLikes(5);
post.setLocationLat(5);
post.setLocationLong(5);
post.setPhotoUrl("URL" + "/" + j);
post.setTitle("Title" + "/" + j);
post.setUser(user);
post.setTags(new ArrayList<>());
ps.add(post);

这是异常消息(PostsService.java:38 是行):em.persist(post);

Exception in thread "main" javax.persistence.PersistenceException: org.hibernate.PersistentObjectException: detached entity passed to persist: jovan.sf_62_2017.postsportal.pojo.Post at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:149) at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:157) at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:164) at org.hibernate.internal.SessionImpl.firePersist(SessionImpl.java:789) at org.hibernate.internal.SessionImpl.persist(SessionImpl.java:767) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.springframework.orm.jpa.ExtendedEntityManagerCreator$ExtendedEntityManagerInvocationHandler.invoke(ExtendedEntityManagerCreator.java:350) at com.sun.proxy.$Proxy85.persist(Unknown Source) at jovan.sf_62_2017.postsportal.services.implementations.PostsService.add(PostsService.java:38) at jovan.sf_62_2017.postsportal.PostsPortalApplication.main(PostsPortalApplication.java:67)

Caused by: org.hibernate.PersistentObjectException: detached entity passed to persist: jovan.sf_62_2017.postsportal.pojo.Post at org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:124) at org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:58) at org.hibernate.internal.SessionImpl.firePersist(SessionImpl.java:782) ... 9 more

最佳答案

首先请更改:

cascade=CascadeType.ALL

至:

cascade = {CascadeType.PERSIST, CascadeType.MERGE}

因为使用 CascadeType.ALL 时会自动继承 CascadeType.REMOVE,但实体删除不仅应用于链接表,还应用于关联的另一端。( see hear )

所以试试这个代码:

    @ManyToMany(mappedBy = "posts", 
cascade = {CascadeType.PERSIST, CascadeType.MERGE})
private List<Tag> tags;




@ManyToMany(cascade =
{CascadeType.PERSIST, CascadeType.MERGE})
@JoinTable(name = "post_tag",
joinColumns = {
@JoinColumn(
name = "tag_id",
referencedColumnName = "id"
)
},
inverseJoinColumns = {
@JoinColumn(
name = "post_id",
referencedColumnName = "id"
)
}
)
private List<Post> posts;

但是你的问题......您尝试使用持久方法将分离的对象((意味着该对象的实例已保存到数据库中,但该对象不在 session 中))保存到数据库:

 Post post = new Post();
post.setId(j);
.
.
.
em.persist(post)

persist 方法旨在将一个新实体(未设置 id)实例添加到持久化上下文中,即将实例从 transient 状态转换为持久状态。

我们通常在想要向数据库插入一条记录(持久化一个实体实例)时调用它所以如果您的对象具有 transient 或持久状态,您可以使用 persist 方法,但如果您的对象在分离之前您应该使用 merge 方法来保存它

关于java - 在 H2 中持久化 ManyToMany 实体会引发异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50214915/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com