org.hibernate.HibernateException

本文描述了在使用Hibernate框架进行数据库操作时遇到的一个常见错误:尝试更改作为主键的标识符导致的HibernateException异常。文章分析了异常产生的原因,并解释了在循环插入数据库的过程中如何避免该问题。
org.hibernate.HibernateException: identifier of an instance of com.** was altered from 20150314000002 to 20150318000001

描述:循环插入数据库时出现此异常
原因:hibernate缓存中的id改变,而数据库中此id为主键不允许修改,试图修改数据库中的主键造成的
对于 `org.hibernate.HibernateException: collection is not associated with any session` 错误,虽然给定引用中未直接提及解决该错误的方案,但可以从Hibernate的常见处理思路来分析可能的解决方法。 一种可能的解决思路是确保集合在使用时关联到一个有效的Hibernate会话。可以考虑使用急切加载(Eager Loading)来避免在会话关闭后访问集合。如引用[3]中展示的使用 `@ManyToMany(fetch = FetchType.EAGER)` 注解,这种方式会在查询主实体时同时加载关联的集合,从而避免在会话关闭后尝试访问集合而引发该错误。 以下是一个简单的示例代码,展示如何使用急切加载来处理集合: ```java import javax.persistence.*; import java.util.Set; @Entity public class Client { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @ManyToMany(fetch = FetchType.EAGER) @JoinTable(catalog = "book_project", name = "client_book", joinColumns = { @JoinColumn(name = "client", referencedColumnName = "name") }, inverseJoinColumns = { @JoinColumn(name = "book", referencedColumnName = "name") }) java.util.Set<Book> books; // Getters and Setters public Long getId() { return id; } public void setId(Long id) { this.id = id; } public Set<Book> getBooks() { return books; } public void setBooks(Set<Book> books) { this.books = books; } } @Entity public class Book { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String name; // Getters and Setters public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } } ``` 此外,还需要确保在事务的环境下执行操作,因为Hibernate的会话通常与事务紧密相关。如果操作不在事务中,可能会导致会话提前关闭,从而使集合失去与会话的关联。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值