a116475939
我是付刚
2015-05-27 05:17
采纳率: 75%
浏览 3.4k
已采纳

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
    hughjin 2015-05-28 10:23
    已采纳
    • com.adon.service.*.*.*(..) 少个星号
    点赞 评论
  • weikzhao0521
    探路者001 2015-05-27 05:49

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

    点赞 评论
  • beacon_2011
    beaconD 2015-05-27 06:32

    你没有加报错回滚@Transactional

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

    点赞 评论
  • u010837612
    君君要上天 2015-05-27 11:19

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

     execution(* com.adon.service..*.*(..))
    
    点赞 评论
  • baidu_25310663
    hughjin 2015-05-28 10:21

    图片说明

    点赞 评论

相关推荐