2 a116475939 a116475939 于 2015.05.27 13:17 提问

spring+mybatis事务不生效,求解

首先是applicationContext.xml文件

    <tx:annotation-driven transaction-manager="transactionManager" />

    <!-- 配置事务管理器 -->
    <bean id="transactionManager"
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    </bean>
    <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="insert*" propagation="REQUIRED"/>
            <tx:method name="save*" propagation="REQUIRED" />
            <tx:method name="update*" propagation="REQUIRED" />
            <tx:method name="modify*" propagation="REQUIRED" />
            <tx:method name="edit*" propagation="REQUIRED" />
            <tx:method name="del*" propagation="REQUIRED" />
            <tx:method name="remove*" propagation="REQUIRED" />
            <tx:method name="get*" propagation="SUPPORTS" read-only="true"/>
            <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
            <tx:method name="load*" propagation="SUPPORTS" read-only="true"/>
            <tx:method name="search*" propagation="SUPPORTS" read-only="true"/>
        </tx:attributes>
    </tx:advice>
    <aop:config>
        <aop:pointcut id="transactionPointcut"
            expression="execution(* com.adon.service..*.*(..))" />
        <aop:advisor pointcut-ref="transactionPointcut"
            advice-ref="transactionAdvice" />
    </aop:config>

接下来是service实现类中的代码

    public JSONObject confirmPassport(String id)  throws Exception{
        PassPortManage pm = new PassPortManage();
        JSONObject json = new JSONObject();
        try {
            pm.setId(new BigDecimal(id));
            //已确认
            pm.setConfirmed(new BigDecimal("1"));
            Integer i = passPortManageMapper.updateByPrimaryKeySelective(pm);
            int q = 5/0;

            if(1==i){
                json.put("success", true);
                json.put("msg", "签收成功!");
            }else{
                json.put("success", false);
                json.put("msg", "签收失败(sql异常)");
            }

        } catch (Exception e) {
            e.printStackTrace();
            json.put("success", false);
            json.put("msg", "签收失败(其他异常)");
            throw new RuntimeException();
        }
        return json;
    }

在int q = 5/0;执行后程序会报错,但记录依旧更改了
求大侠们指教

5个回答

baidu_25310663
baidu_25310663   2015.05.28 18:23
已采纳
  • com.adon.service.*.*.*(..) 少个星号
weikzhao0521
weikzhao0521   2015.05.27 13:49

没有交给spring去管理事务,所以更新是报错没有回滚。
在你的更新方法上加上annocation @Transactional

beacon_2011
beacon_2011   Rxr 2015.05.27 14:32

你没有加报错回滚@Transactional

加在service实现类方法名的上面

u010837612
u010837612   2015.05.27 19:19

我觉得可能是这个有问题,service后面是不是多了一个点

 execution(* com.adon.service..*.*(..))
baidu_25310663
baidu_25310663   2015.05.28 18:21

图片说明

Csdn user default icon
上传中...
上传图片
插入图片