3:通过<tx:advice>配置事务增强,绑定事务管理并针对不同的方法定义 事务规则。
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:method name="find*" read-only="true" propagation="SUPPORTS" timeout="1000" isolation="SERIALIZABLE" />
<tx:method name="*" propagation="REQUIRED"/>
从<!--配置切面-->里面的切点表达式里面切中的所有方法中筛选符合<!--配置增强-->里面的name属性要求的方法
<aop:pointcut expression="execution(* cn.smbms.service..*.*(..))" id="myPoint"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="myPoint"/>
--------------补充-----------------
REQUIRED(默认值):如果存在一个事务则加入到一个事务,如果不存在事
SUPPORTS: 如果存在事务方法当中,则加入事务。如果不存在事务,则以非事务方式运
1. DEFAULT: 这是TransactionManager默认的隔离级别,使用数据库默认的事务隔离级别.
2. READ_UNCOMMITTED: 这是事务最低的隔离级别,充许令外一个事务可以看到这个事务未提交的数据。
3. READ_COMMITTED: 保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据
4. REPEATABLE_READ: 这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻像读。
它除了保证一个事务不能读取另一个事务未提交的数据外,还保证了避免下面的情况产生(不可重复读)。
5. SERIALIZABLE 这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。
timeout:设置事务的最长运行时间s。一般默认是-1,永不超时。
Read-only:设置事务是否为只读,默认值是false,可以提高性能
Spring默认值在抛出runtimeException时才标识事务回滚
可以通过完全限定类名指定需要回滚事务的异常。多个类名用逗号隔开
Spring默认checked Exception不会触发事务回滚
可以通过完全限定类名指定不需要回滚事务的异常。多个类名逗号隔开
--------------------补充结束--------------------
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>