关于spring整合hibernate使用update无异常但没有效果(不输出sql语句)

  • 2019 年 10 月 8 日
  • 筆記

单独使用hibernate时

openSession()

在没有使用spring控制事务时,使用的是sessionFactory.openSession()。这样每个方法都会新建一个session,必须在方法中控制和关闭session。

于是一开始我直接在try-with-resource语句中使用session的update等方法,无任何事务,在单元测试时发现update方法无效。

解决方法有两种:

  • 加上事务控制: session.beginTransaction()和trans.commit()
  • 加上flush方法: session.flush()

session原理:其实我们执行session更新和删除操作的时候,不会立即执行,要执行flush才可执行。但是如果配置了事务管理,这件事就可以交给事务管理器去完成,在事务提交的时候执行自动执行flush语句

使用Spring事务管理

  1. 需要使用getCurrentSession获取session
  2. 在操作中不要显示的关闭session
  3. 不需要进行编码式事务,使用声明式事务

在spring配置文件中添加如下代码

此时的dao层只需要简单的 session().update(entity)就行了

使用Spring事务注解管理

确定了事务问题,但是事务配置有没有错误。

错误原因:是配置出现了问题:

web.xml

问题是:spring-mvc.xml由servlet加载的时候

如果一开始就注册所有的注解,那么,遇到@service的时候,事务配置就很可能无效,尤其是@Transactional一定失效。所以事务配置就不管用

解决方案:分开加载控制器和其他注解。控制器的注解由springmvc.xml加载

spring配置文件中,加载其他注解:

这样就配置好了运行起来控制台也打印hql语句了