我的源码
public Session getCurrentSession() {
Session session = null;
System.out.println("这是baseDao的session");
try {
session = sessionFactory.getCurrentSession();
} catch (Exception e) {
// TODO: handle exception
System.out.println(e);
}
return session;
}@Override
public void delete(T entity) {
getCurrentSession().delete(entity);
}此时删除的话会抛出异常
原因是:一个detached instance是一个已经持久化的对象,但是它的Session已经关闭了,它的引用依然有效,当然,detached instance可能被修改。detached instance能够在以后可以重新附属到一个新的Session,使之能重新序列化。
解决方案:在删除之前把这个Detached instance绑定到当前的Sesssion.
具体修改代码:
@Override
public void delete(T entity) {
getCurrentSession().update(entity);
getCurrentSession().delete(entity);
}
本文介绍了一种在Java中处理DetachedInstance异常的方法。当尝试删除一个已经与Session分离的对象时,可能会遇到此异常。文章提供了具体的代码示例,并解释了如何通过先更新再删除来避免异常。

686

被折叠的 条评论
为什么被折叠?



