事务管理接口
编程式事务管理(基于Java编程控制,很少使用)
利用TransactionTemplate将多个DAO操作封装起来
声明式事务管理(基于Spring的AOP配置控制)
- 基于TransactionProxyFactoryBean的方式.(很少使用)
需要为每个进行事务管理的类,配置一个TransactionProxyFactoryBean进行增强.
- 基于XML配置(经常使用)
一旦配置好之后,类上不需要添加任何东西。
如果Action作为目标对象切入事务,需要在<aop:config>元素里添加proxy-target-class="true"属性。原因是通知Spring框架采用CGLIB技术生成具有事务管理功能的Action类。
- 基于注解(配置简单,经常使用)
声明式事务-基于XML配置
事务管理
<!-- 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<!-- 配置事务的通知 -->
<!-- propagation :事务传播行为
isolation :事务的隔离级别
read-only :只读
rollback-for:发生哪些异常回滚
no-rollback-for :发生哪些异常不回滚
timeout :过期信息-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="transfer" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
<!-- 配置切面 -->
<aop:config>
<!-- 配置切入点 -->
<aop:pointcut expression="execution(* com.zs.spring.demo3.AccountService+.*(..))" id="pointcut1"/>
<!-- 配置切面 -->
<aop:advisor advice-ref="txAdvice" pointcut-ref="pointcut1"/>
</aop:config>
*<tx:method/> 有关的设置
声明式事务-基于注解
注释
@Transactional 可以作用于接口、接口方法、类以及类方法上。当作用于类上时,该类的所有 public 方法将都具有该类型的事务属性,同时,我们也可以在方法级别使用该标注来覆盖类级别的定义。
第二种(代码)
private SqlSessionTemplate sqlSessionTemplate;
// 新获取一个模式为BATCH,自动提交为false的session
SqlSession session_business = sqlSessionTemplate.getSqlSessionFactory().openSession(ExecutorType.BATCH,false);
//通过新的session获取mapper
businessDAO = session_business.getMapper(BusinessDbOptDAO.class);
//操作数据库
businessDAO.deleteLastData("BASE_SINGLE_CHANNEL_DATA");
//提交
session_business.commit();
//清理缓存,防止溢出
session_business.clearCache();
//有问题回滚
session_business.rollback();
//关闭
session_business.close();
事务与非事务
事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit)
以事务方式运行,是说如果执行多条SQL语句,则要么都成功,要么都失败
以非事务方式运行,是说如果执行多条SQL语句,彼此没有关系
参考:https://www.cnblogs.com/kenking/p/6160505.html
https://www.ibm.com/developerworks/cn/education/opensource/os-cn-spring-trans/