标签:方法 comm 提交 ext into poi except cte 查看
Spring提供了统一的事务抽象,可以让我们以统一的Api进行事务管理。具体的操作交给不同的TransitionManager实现完成。

PlatformTransactionManager - 根据TransitionDefinition创建事务、事务回滚、事务提交
getTransaction() - 开启事务TransitionDefinition - 定义事务特征,比如传播机制、隔离界别、readonly、timeout、遇到什么异常回滚
TransactionStatus - 保存事务状态
Propagation - 传播行为,一般查询方法使用SUPPORTS,更新、插入、删除方法使用REQUIRED
Isolation - 隔离级别
TransitionTemplate - 用于编程式事务(用法类似JdbcTemplate)
TransitionCallback/TransactionCallbackWithoutResult- 给TransationTemplate提供回调
1??配置TransactionManager(事务管理器)
<!-- spring-tx - 事务管理器-->
<bean id="transtionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 事务超时时间 default -1 -->
<property name="defaultTimeout" value="-1" />
<property name="dataSource" ref="datasource" />
</bean>
2??开启@Transaction注解支持
<!-- 声明式事务 - 开启注解 -->
<tx:annotation-driven transaction-manager="transtionManager" />
3?? 使用@Tranaction注解?
/*
* 使用事务 - @Transitional
* */
@Transactional
public void insert() {
// 1. 插入数据
int update = jdbcTemplate.update("insert into tb_area value (null,‘东校区‘)");
// 2. 抛出异常
throw new RuntimeException("出现了错误");
// 3. 查看是否回滚
}
1?? 配置TransactionManager
<!-- spring-tx - 事务管理器-->
<bean id="transtionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 事务超时时间 default -1 -->
<property name="defaultTimeout" value="-1" />
<property name="dataSource" ref="datasource" />
</bean>
2?? 使用<tx:advice>定义事务切面
<!-- 声明式事务 - 开启注解 -->
<tx:advice id="txAdvice" transaction-manager="transtionManager">
<tx:attributes>
<tx:method name="*" />
</tx:attributes>
</tx:advice>
3??把?<tx:advice>事务切面织入到target
<!-- 配置aspectj - 切面 -->
<aop:config>
<aop:pointcut id="pc" expression="execution(* com.yuki.tx.XmlService.*(..))"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="pc" />
</aop:config>
有两种方式
TransactionManager - 自己控制事务,自己决定什么时候rollback和commitTransactionTemplate - 只用提供回调,方法抛RuntimeException回滚/*
* 使用事务 -
* DefaultTransactionDefinition - 定义事务特征,比如propagation、isolation
* TransactionManager - 事务管理
* */
public void useTxManager() {
// 1. 初始化TransitionDefinition -
DefaultTransactionDefinition transitionDefinition = new DefaultTransactionDefinition();
transitionDefinition.setPropagationBehavior(Propagation.REQUIRED.value());
// 2. 开启事务
TransactionStatus transactionStatus = transactionManager.getTransaction(transitionDefinition);
try {
// 1. 插入数据
int update = jdbcTemplate.update("insert into tb_area value (null,‘东校区‘)");
// 2. 抛出异常
if(update == 1) {
throw new RuntimeException("出现了错误");
}
transactionManager.commit(transactionStatus);
}catch (Exception e) {
e.printStackTrace();
transactionManager.rollback(transactionStatus);
}
}
1??配置TransactionTemplate
<!-- 编程式 - 事务 -->
<bean id="transactionTemplate" class="org.springframework.transaction.support.TransactionTemplate">
<property name="transactionManager" ref="transtionManager" />
</bean>
使用TranactionTemplate,并使用TransactionCallback提供回调
/*
* 使用事务 -
* TransitionTemplate - 类似JdbcTemplate,内部视同TransactionManager进行事务操作
* TransitionCallabck、TransactionCallbackWithoutResult - 提供回调
* */
public void useTxTemplate() {
transactionTemplate.execute(new TransactionCallback() {
public Object doInTransaction(TransactionStatus transactionStatus) {
int update = jdbcTemplate.update("insert into tb_area value (null,‘东校区‘)");
// 2. 抛出异常
if(update == 1) {
throw new RuntimeException("出现了错误");
}
// 3. 返回值
return update;
}
});
}
标签:方法 comm 提交 ext into poi except cte 查看
原文地址:https://www.cnblogs.com/yuki2333/p/14584242.html