对于SSI中的action的数据回滚的疑问

最近看了公司的一个框架,很是不明白。框架是用struts,spring,mybatis搭建起来的。简化下就是三层,action,service,dao。事物控制放在了service层。action层只负责页面跳转,以及调用service层。
可是如果一个请求,在service层执行成功后,在action负责跳转的时候产生了一个异常。这个时候数据已经写入到了数据库,我该如何将写入的数据回滚呢?或者我如何修改这个框架的配置。

spring的配置如下:

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"
     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xmlns:aop="http://www.springframework.org/schema/aop"
     xmlns:tx="http://www.springframework.org/schema/tx"
     xmlns:jdbc="http://www.springframework.org/schema/jdbc"
     xmlns:context="http://www.springframework.org/schema/context"
     xsi:schemaLocation="
     http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
     http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
     http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd
     http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
     http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">

    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
         <property name="driverClassName"  value="com.mysql.jdbc.Driver" />  
        <property name="username" value="root" />  
        <property name="password" value="123456" />  
        <property name="url"  value="jdbc:mysql://127.0.0.1:3306/ci" />  
    </bean>
    
            <!-- define the SqlSessionFactory -->
    <bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="typeAliasesPackage" value="com.leopardsnow.ci.domain" />
    </bean>
    
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    </bean>
      

    <context:component-scan base-package="com.leopardsnow.ci.service" />
    <context:annotation-config />
    <tx:annotation-driven />
    
    <!-- 从base 包中搜索所有下面所有 interface,并将其注册到 Spring Bean容器中,其注册的class bean是MapperFactoryBean。 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.leopardsnow.ci.mapper" />
    </bean>
 
    
</beans>

 

一般需要做事务处理的异常都是从底层DAO一层层抛上来的,如果事务切面中对相应异常做了检测,就会rollback,按你这种说法,异常是在action中抛出的,除非你对action做切面,检测action抛出的异常,才有可能rollback,但是常规的做法是事务一般处理事务数据处理过程中出现的异常,在action中返回的这种和事务处理无关的异常是不需要回滚的

你已经加了







那么需要在Service 方法 对所有调用后台的方法中加上
@Transactional//放在这里表示所有方法都加入事务管理

public class AnnotationUserServiceImpl implements IUserService {

应该配置成发生了BusinessException就回滚吧

我最近也在困惑这个问题。。。坐等大牛回复

是如果一个请求,在service层执行成功后,在action负责跳转的时候产生了一个异常

这种错误应该程序上线就应该被发现出来的,而不是程序运行时候的异常。

是,service层业务逻辑执行完毕以后,返回视图层,action转发。如果这时候出现异常信息,则应该是bug范畴之内的,而不是程序在发布后运行期可能会出现的错误行为。
事务的一致性,一般是对于多线程来说的,比如多个用户修改同一数据,事务必须保持其数据的完整性和一致性。

如果action层出现exception异常之类的,应该属于代码有问题,如果需要在action层异常进行回滚的是,那证明action中执行块和service中是属于同一事务的,必须有一个事务进行控制,把action层的和service中的需要同一个事务控制的,都放到service层中进行处理。action层本身设计来就是作为数据接收验证以及调用service层最后进行叶面跳转。

个人拙见,事务已经提交的数据,在action里面没法回滚,如果是在service里面,有事务代理,那肯定是可以回滚的,就像上面那个哥们说的一样,跳转的异常,那在项目上线的时候根本不会出现,就算出现了,也不会影响数据的生产,只是一个页面找不到的问题。