save()方法添加数据了,可是delete()和Update()方法总是没有效果
在用ssh做一个web项目里,save()方法添加数据了,可是delete()和Update()方法总是没有效果,当然查询方法也有效。
经分析,可能的原因有两个:
1、是事务回滚了
2、是session中的数据没刷新
第一种情况是加了事务,但是没有调用事务的commit()方法,由于我的项目将service层与dao层合并了,serviceImpl继承了daoSupportImpl,但是子类中对事务的注解,对父类的方法没有效,所以这也会出现上述的异常。
第二种情况是数据没刷新,刚好在项目中为了解决no session or session was closed 的问题,我在web.xml中配了spring
OpenSessionInViewFilter,这可能会出现事务已经提交,然后你再执行delete()或update()方法,这里就不再flush()了,flush方法的
主要作用就是清理缓存,强制数据库与hibernate缓存同步,在一些复杂的对象更新和保存的过程中就要考虑数据库操作顺序的改
变以及延时flush是否对程序的结果有影响。如果确实存在着影响,那就可以在需要保持这种操作顺序的位置加入flush强制
Hibernate将缓存中记录的操作flush入数据库
解决办法:在delete()和update()方法后面加入flush()即可
if(obj!=null)
getSession().delete(obj);
public void update(T entity) {
getSession().update(entity);
getSession().flush();
}
也可以在父类中也注解@Transactional,因为在子类中注解了,但父类中的方法无效。
在用ssh做一个web项目里,save()方法添加数据了,可是delete()和Update()方法总是没有效果,当然查询方法也有效。
经分析,可能的原因有两个:
1、是事务回滚了
2、是session中的数据没刷新
第一种情况是加了事务,但是没有调用事务的commit()方法,由于我的项目将service层与dao层合并了,serviceImpl继承了daoSupportImpl,但是子类中对事务的注解,对父类的方法没有效,所以这也会出现上述的异常。
第二种情况是数据没刷新,刚好在项目中为了解决no session or session was closed 的问题,我在web.xml中配了spring
OpenSessionInViewFilter,这可能会出现事务已经提交,然后你再执行delete()或update()方法,这里就不再flush()了,flush方法的
主要作用就是清理缓存,强制数据库与hibernate缓存同步,在一些复杂的对象更新和保存的过程中就要考虑数据库操作顺序的改
变以及延时flush是否对程序的结果有影响。如果确实存在着影响,那就可以在需要保持这种操作顺序的位置加入flush强制
Hibernate将缓存中记录的操作flush入数据库
解决办法:在delete()和update()方法后面加入flush()即可
public void delete(Long id) {
if(obj!=null)
getSession().delete(obj);
getSession().flush();
public void update(T entity) {
getSession().update(entity);
getSession().flush();
}
也可以在父类中也注解@Transactional,因为在子类中注解了,但父类中的方法无效。
两种方法都可以,,,建议用第二种。