package com.aqiuo.service.impl;
import com.aqiuo.dao.AccountMapper;
import com.aqiuo.pojo.Account;
import com.aqiuo.service.AccountService;
import org.springframework.jdbc.core.JdbcTemplate;
import java.sql.Connection;
import java.sql.SQLException;
/**
* 账户的业务层实现类,实现新增的两条数据
*
*/
public class AccountServiceImpl implements AccountService {
AccountMapper accountMapper;
JdbcTemplate jdbcTemplate;
public void setAccountMapper(AccountMapper accountMapper) {
this.accountMapper = accountMapper;
}
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
public boolean pay(Integer money, Integer produce, Integer customer) throws SQLException {
Connection connection=jdbcTemplate.getDataSource().getConnection();
connection.setAutoCommit(false);
try {
accountMapper.addMoney(money, produce);
accountMapper.subMoney(money, customer);
connection.commit();
}catch (Exception e){
connection.rollback();
e.printStackTrace();
}finally {
connection.close();
}
return false;
}
}
(用的一个DataSource)
属性名称 | 值 | 事务管理员 | 事务协调员 |
PROPAGATION_REQUIRED | REQUIRED | 开启T 无 | 加入T 新建T |
PROPAGATION_SUPPORTS | SUPPORTS | 开启T 无 | 加入T 无 |
PROPAGATION_MANDATORY | MANDATORY | 开启T 无 | 加入T ERROR |
PROPAGATION_REQUIRES_NEW | REQUIRES_NEW | 开启T 无 | 新建T2 新建T2 |
PROPAGATION_NOT_SUPPORTED | NOT_SUPPORTED | 开启T 无 | 无 无 |
PROPAGATION_NEVER | NEVER | 开启T 无 | ERROR 无 |
PROPAGATION_NESTED | NESTED |
事务管理过程中,传播行为可以控制是否需要创建以及如何创建事务。
Spring2.0以后,提供了tx命名空间来配置事务。tx命名空间下提供了元素来配置事务的通知。
当使用元素配置事务增强后,可以编写AOP配置,让Spring自动对目标生成代理
name | 该属性为必选属性,指定了与事务属性相关的方法名,其属性支持通配符,例如:'get* ' |
propagation | 用于指定事务的传播行为,默认值是REQUIRED |
isolation | 用于指定事务的隔离级别,默认为DEFAULT |
read-only | 用于指定事务是否只读,默认为false |
timeout | 用于指定事务超时的时间,默认为-1,即永不超时 |
rollback-for | 用于指定触发事务回滚的异常类 |
no-rollback-for | 用于指定不触发事务回滚的异常类 |
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd " >
<!-- 配置数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<!-- 数据库驱动 -->
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property>
<!-- 数据库的连接路径 -->
<property name="url" value="jdbc:mysql://localhost:3306/spring"></property>
<!-- 连接数据库的用户名 -->
<property name="username" value="root"></property>
<!-- 连接数据库的密码 -->
<property name="password" value="3.14159265358"></property>
</bean>
<!-- 配置jdbcTemplate -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 注入 -->
<bean id="accountDao" class="com.aqiuo.jdbc.AccountDaoImpl">
<property name="jdbcTemplate" ref="jdbcTemplate"></property>
</bean>
<!-- 事务管理器,依赖于数据源 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 编写事务通知,对事务进行增强 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" propagation="REQUIRED" isolation="DEFAULT" read-only="false"></tx:method>
</tx:attributes>
</tx:advice>
<!-- 编写AOP,让Spring自动对目标生成代理,需要AspectJ的表达式 -->
<aop:config>
<aop:pointcut expression="execution(* com.aqiuo.*.*.*(..))" id="txPointCut"></aop:pointcut>
<!-- 切面,将切入点与通知整合 -->
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointCut"></aop:advisor>
</aop:config>
</beans>
Spring的声明式事务管理通过注解非常简单
步骤:
<tx:annotation-driver transaction-manager="transactionManager" />
@Transactional可配置的参数
value | 用于指定事务管理器 |
transactionManager | 指定事务的限定符值,同value |
isolation | 指定事务的隔离级别 |
noRollbackFor | 指定遇到特定异常时强制不会滚事务 |
noRollBackForClassName | 指定遇到特定的多个异常时强制不会滚事务,属性值可以指定多个异常类名 |
propagation | 用于指定事务的传播行为 |
read-only | 用于指定事务是否只读 |
rollback-For | 指定遇到特定异常时强制回滚事务 |
rollbackForClassName | 指定遇到特定的多个异常时强制回滚事务,属性值可以指定多个异常类名 |
time | 指定事务的超时时长 |
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.3.xsd " >
<!-- 配置数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<!-- 数据库驱动 -->
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property>
<!-- 数据库的连接路径 -->
<property name="url" value="jdbc:mysql://localhost:3306/spring"></property>
<!-- 连接数据库的用户名 -->
<property name="username" value="root"></property>
<!-- 连接数据库的密码 -->
<property name="password" value="3.14159265358"></property>
</bean>
<!-- 配置jdbcTemplate -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 注入 -->
<bean id="accountDao" class="com.aqiuo.jdbc.anno.AccountDaoImpl">
<property name="jdbcTemplate" ref="jdbcTemplate"></property>
</bean>
<!-- 事务管理器,依赖于数据源 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<tx:annotation-driven transaction-manager="transactionManager" />
</beans>
注意:
1.配置文件方式:
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="find*" isolation="DEFAULT"/>
<tx:method name="pay" isolation="DEFAULT"></tx:method>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:advisor advice-ref="txAdvice" pointcut="execution(public * com.aqiuo.service.impl.AccountServiceImpl.*(..))"></aop:advisor>
</aop:config>
2.配置文件+注解:
<tx:annotation-driven transaction-manager="transactionManager"></tx:annotation-driven>
3.纯注解方式:
@EnableTransactionManager @Transactional