Spring 使用Hibernate事务管理:update等操作无效果问题

Spring 使用Hibernate事务管理:update等操作无效果问题

使用Spring事务管理

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

实际问题:

  1. 经常会遇到事务管理使用hibernate时,在调用update方法时,数据返回正确,而数据库却没有更新
  2. 调用save保存数据时,返回存储成功,数据库没有更新
  3. 删除数据时删除成功,数据库依然没有更新等问题

原因:

  1. applicationContext.xml(类似同名)配置文件中,针对hibernate的事务管理配置与service定义的方法名称不相符
  2. 事物配置中定义了只读权限,因此修改失败
  3. 事物配置未覆盖定义service
  4. springmvc与hibernate的扫描位置冲突

详细解释:

  • 事物配置中定义了类似【<tx:method name="update*" propagation="REQUIRED" />】的属性,即意味着以update开头的service具备了操作权限,但是如果用户自己定义的update拼写错误如拼写为updata等是无法真正更新成功的。
  • <tx:method name="change*" propagation="REQUIRED" />定义了此属性,却命名service名称以其他方式开头如update这样依然是无法更新成功的。
  • <tx:method name="update*" propagation="REQUIRED" read-only="true" />,属性中限制了只能读取的操作,因此依然无法更新成功

name

与事务属性关联的方法名。通配符(*)可以用来指定一批关联到相同的事务属性的方法。 如:'get*''handle*''on*Event'等等。

propagation 不 REQUIRED 事务传播行为

REQUIRED:支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。
SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方式执行。
MANDATORY:支持当前事务,如果当前没有事务,就抛出异常。
REQUIRES_NEW:新建事务,如果当前存在事务,把当前事务挂起。
NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
NEVER:以非事务方式执行,如果当前存在事务,则抛出异常。
NESTED:支持当前事务,如果当前事务存在,则执行一个嵌套事务,如果当前没有事务,就新建一个事务。

isolation 不 DEFAULT 事务隔离级别 timeout 不 -1 事务超时的时间(以秒为单位) read-only 不 false 事务是否只读? rollback-for

将被触发进行回滚的 Exception(s);以逗号分开。 如:'com.foo.MyBusinessException,ServletException'

no-rollback-for

被触发进行回滚的 Exception(s);以逗号分开。 如:'com.foo.MyBusinessException


实例:(详细列举了各类配置方式)

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

 <!-- 在 IOC 容器中配置 Hibernate 的事务管理器 -->   <bean        >       <property name="sessionFactory" ref="sessionFactory"></property>    </bean>    <!-- 配置事务通知属性 -->    <tx:advice  transaction-manager="transactionManager">        <!-- 定义事务传播属性 -->        <tx:attributes>            <tx:method name="insert*" propagation="REQUIRED" />            <tx:method name="update*" propagation="REQUIRED" />            <tx:method name="edit*" propagation="REQUIRED" />            <tx:method name="save*" propagation="REQUIRED" />            <tx:method name="add*" propagation="REQUIRED" />            <tx:method name="new*" propagation="REQUIRED" />            <tx:method name="set*" propagation="REQUIRED" />            <tx:method name="remove*" propagation="REQUIRED" />            <tx:method name="delete*" propagation="REQUIRED" />            <tx:method name="change*" propagation="REQUIRED" />            <tx:method name="get*" propagation="REQUIRED" read-only="true" />            <tx:method name="find*" propagation="REQUIRED" />            <tx:method name="load*" propagation="REQUIRED" read-only="true" />            <tx:method name="*" propagation="REQUIRED"/>        </tx:attributes>    </tx:advice>


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

推荐阅读