一、回顾事务
1、把一组业务当成一个业务来做;要么都成功,要么都失败!
2、事务在项目开发中之分的重要,涉及到数据的一致性问题,不能马虎!
3、确保完整性和一致性
事务ACID原则:
· 原子性
· 一致性
· 隔离性
· 多个业务可能操作同一个资源,防止数据损坏
· 持久性
· 事务一旦提交,无论系统发生什么问题,结果都不会再被影响,被持久化的写到存储器中!
本质上就是Mybatis的增删改查以及各种方法的实现!
<select id="selectUser" resultType="user"> select * from mybatis </select> <insert id="addUser" parameterType="user"> insert into mybatis (id,name,sex,addr) values (#{id},#{name},#{sex},#{addr}); </insert> <delete id="deleteUser" parameterType="int"> delete from mybatis where id=#{id} </delete>
二、spring中的事务管理
· 事务式事务:AOP
· 编程式事务:需要在代码中进行事务的管理
思考:
为什么需要事务?
· 如果不配置事务,可能存在数据提交不一致的情况;
· 如果我们不在SPRING中去配置声明式事务,我们就需要在代码中手动配置事务!
· 事务在项目的开发中十分重要,设计到数据的一致性和完整性,不容马虎!
配置声明式事务的代码如下:
<!--配置声明式事务-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="datasource"></property>
</bean>
<!--结合AOP实现事务的织入-->
<!--配置事务通知:-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<!--给那些方法配置事务-->
<!--配置事务的传播特性:propagetion=-->
<tx:attributes>
<tx:method name="add" propagation="REQUIRED"/>
<tx:method name="delete" propagation="REQUIRED"/>
<tx:method name="update" propagation="REQUIRED"/>
<tx:method name="query" read-only="true"/>
<tx:method name="*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
<!--配置事务切入-->
<aop:config>
<aop:pointcut id="txPointCut" expression="execution(* com.z.mapper.*.*(..))"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointCut"/>
</aop:config>
实际上,需要改变的地方只有路径这里,其他原封不动
<aop:pointcut id="txPointCut" expression="execution(* com.z.mapper.*.*(..))"/>
但是需要修改spring-dao.xml也就是此配置文件上面的语句 如下
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">