事务的四个属性ACID
原子性:事务动作要么全部完成,要么完全不起作用
一致性:一旦所有事务动作完成,事务就要被提交
隔离性:多个事务同时处理相同的数据时,每个事务隔离开来防止数据损坏
持久性:事务的结果被写到持久化存储器中,事务一旦完成,无论系统发生什么错误,结果都不会受到影响
在之前的案例中,我们给userDao接口新增删除和增加用户的方法
int addUser(User user);
int deleteUser(int id);
在mapper配置文件中我们故意把delete写错
<insert id="addUser" parameterType="User">
insert into user (id,name,pwd) values (#{id},#{name},#{pwd})
</insert>
<delete id="deleteUser" parameterType="int">
deletes from user where id = #{id}
</delete>
修改实现类
@Override
public List<User> selectUser() {
User user = new User(12, "嘎子", "123456");
UserMapper mapper = getSqlSession().getMapper(UserMapper.class);
mapper.addUser(user);
mapper.deleteUser(12);
return mapper.selectUser();
}
@Override
public int addUser(User user) {
UserMapper mapper = getSqlSession().getMapper(UserMapper.class);
return mapper.addUser(user);
}
@Override
public int deleteUser(int id) {
UserMapper mapper = getSqlSession().getMapper(UserMapper.class);
return mapper.deleteUser(id);
}
报错:sql异常,delete写错了, 结果 :插入成功!但我们想让他们都成功才成功,有一个失败,就都失败,需要用到事务
Spring支持编程式事务管理和声明式的事务管理,编程式事务管理将事务管理代码嵌到业务方法中来控制事务的提交和回滚,声明式事务管理将事务管理代码从业务方法中分离出来,以声明的方式来实现事务管理
我们在这里使用声明式事务管理,只需要配置即可
引入支持事务的约束
xmlns:tx="http://www.springframework.org/schema/tx"
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd
无论是使用Spring的编程式还是者声明式事务管理策略,事务管理器都是必须的
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
配置事务的通知
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="add" propagation="REQUIRED"/>
<tx:method name="delete" propagation="REQUIRED"/>
<tx:method name="update" propagation="REQUIRED"/>
<tx:method name="search*" propagation="REQUIRED"/>
<tx:method name="get" read-only="true"/>
<tx:method name="*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
引入支持aop的约束
xmlns:aop="http://www.springframework.org/schema/aop"
http://www.springframework.org/schema/aop
https://www.springframework.org/schema/aop/spring-aop.xsd
配置aop
<aop:config>
<aop:pointcut id="txPointcut" expression="execution(* com.dream.dao.*.*(..))"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
</aop:config>