Spring+mysql事务处理中的问题

看这篇文章看的很爽http://www.iteye.com/topic/78674
就做了一个事务处理的测试程序。struts+spring+ibatis+mysql+tomcat5.5利用的是声明式的处理方式。把事务处理的逻辑放在了service层并在xml声明切面和切点。

service层代码如下

public class TrasacationTest {
CardLibDAO cardLibDAO;

public void setCardLibDAO(CardLibDAO cardLibDAO) {
this.cardLibDAO = cardLibDAO;
}
public void tt() throws Exception
{
this.cardLibDAO.insertCardLib(new CardLib());
this.ex();
}
public void ex() throws Exception
{
throw new RuntimeException("从Transaction抛出");
}
}

xml配置如下

<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<aop:config>

<aop:advisor id="testadvisor" pointcut="execution(* com.xx.xx.service.*.tt*(..))" advice-ref="transactionadvice"/>

</aop:config>


<tx:advice id="transactionadvice" transaction-manager="txManager">
<tx:attributes>
<tx:method name="tt" rollback-for="java.lang.RuntimeException"/>
</tx:attributes>
</tx:advice>



当刚刚测试的时候插库动作总是能成功,并不回滚。经过查看代码和配置确定没有问题。突然想到mysql数据库默认情况下不支持事务,察看一下mysql配置,果真是默认的MyISAM.重新配置mysql支持事务。测试通过。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值