Spring中@Transactional事务回滚实例及源码.docx
文本预览下载声明
一、使用场景举例在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用。下面举个栗子:比如一个部门里面有很多成员,这两者分别保存在部门表和成员表里面,在删除某个部门的时候,假设我们默认删除对应的成员。但是在执行的时候可能会出现这种情况,我们先删除部门,再删除成员,但是部门删除成功了,删除成员的时候出异常了。这时候我们希望如果成员删除失败了,之前删除的部门也取消删除。这种场景就可以使用@Transactional事物回滚。二、checked异常和unchecked异常这里之所以让大家清楚checked异常和unchecked异常概念,是因为:Spring使用声明式事务处理,默认情况下,如果被注解的数据库操作方法中发生了unchecked异常,所有的数据库操作将rollback;如果发生的异常是checked异常,默认情况下数据库操作还是会提交的。checked异常:表示无效,不是程序中可以预测的。比如无效的用户输入,文件不存在,网络或者数据库链接错误。这些都是外在的原因,都不是程序内部可以控制的。必须在代码中显式地处理。比如try-catch块处理,或者给所在的方法加上throws说明,将异常抛到调用栈的上一层。继承自java.lang.Exception(java.lang.RuntimeException除外)。unchecked异常:表示错误,程序的逻辑错误。是RuntimeException的子类,比如IllegalArgumentException, NullPointerException和IllegalStateException。不需要在代码中显式地捕获unchecked异常做处理。继承自java.lang.RuntimeException(而java.lang.RuntimeException继承自java.lang.Exception)。看下面的异常结构图或许层次感更加深些:三、@Transactional的使用实例本实例采用的是Eclipse+maven,maven只是作为jar管理,即便不了解的maven的猿友也可以读懂。3.1、spring的配置文件里面必须先配置tx名字空间如下:为了使用基于@Transactional的事务管理,需要在Spring中进行如下的配置:bean id=appTransactionManager class=org.springframework.jdbc.datasource.DataSourceTransactionManager property name=dataSource ref=dataSource / /bean tx:annotation-driven proxy-target-class=false transaction-manager=appTransactionManager /博主的整个spring配置文件:?xml version=1.0 encoding=UTF-8?beans xmlns=/schema/beans xmlns:xsi=/2001/XMLSchema-instance xmlns:context=/schema/context xmlns:tx=/schema/tx xmlns:aop=/schema/aop xsi:schemaLocation= /schema/tx/schema/tx/spring-tx-2.5.xsd/schema/beans/schema/beans/spring-beans-3.0.xsd/schema/aop/schema/aop/spring-aop-3.0.xsd/schema/context/schema/context/spring-context-3.0.xsd !-- 引入jdbc配置文件 -- bean id=propertyConfigurer class=org.springframework.beans.factory.config.PropertyPlaceholderConfigurer property name=locations list valueclasspath:properties/*.properties/value !--要是有多个配置文件,只需在这里继续添加即可 -- /list /property /bean !-- 配置数据源 -- bean id=dataSource class=org.springframework.jdbc.datasource.DriverManagerDataSource !-- 不使用properties来配置 -- !-- property name=driverClas
显示全部