1. Spring数据库事务管理器的设计
在Spring中数据库事务是通过PlatformTransactionManager进行管理的。TransactionTemplate源码:
事务的创建、提交和回滚都是通过PlatformTransactionManager接口来完成,当事务产生异常时会回滚事务。在默认的实现中所有的异常都会回滚,我们可以通过配置去修改在某些异常发生时回滚或者不回滚事务。当无异常时会提交事务。
PlatformTransactionManager接口的源码:
1.配置事务管理器
这里先引入了 XML 的命名空间,然后定义了数据库连接池,于是使用了
DataSourceTransactionManager去定义数据库事务管理器,并且注入了数据库连接池。这样,Spring就知道已经将数据库事务委托给事务管理器transactionManger管理。
在Spring中可以使用声明式事务或编程式事务,如今编程式事务几乎不用,因为其会产生冗余,代码可读性差。声明式事务分为xml配置和注解事务,但是xml方法也已经不常用了,目前主流的方法是注解@Transaction。
2.用java配置方法实现Spring数据库事务
用java配置的方式实现Spring数据库事务,需要在配置类中实现接口TransactionManagementConfigurer的annotationDrivenTransactionManager方法。Spring将annotationDrivenTransactionManager方法返回的事务管理器作为程序中的事务管理器。
加粗的代码实现了TransactionManagermentConfigurer接口所定义的方法annotationDrivenTransactionManager,并且我们使用DataSourceTransactionManager去定义数据库事务管理器的实例,再将数据源设置给它。使用注解@EnableTransactionManagement后,在Spring上下文中使用事务注解@Transaction,Spring会知道使用该数据库事务管理器管理事务了。
2. 编程式事务
编程式事务以代码的方式管理事务,事务由开发者通过自己的代码实现,这里需要使用一个事务定义类接口TransactionDefinition。编程式事务的代码如下:
注意加粗的代码,可以看到所有的事务都是由开发者自己进行控制的,由于事务已经交由事务管理器管理,所以jdbcTemplate本身的数据库资源已经由事务管理器管理,因此当执行完insert语句时不会自动提交事务,这时需要使用事务管理器的commit方法,回滚事务需要使用rollback方法。
3.声明式事务
编程式事务是一种约定型事务,大部分情况下,当使用数据库事务时,大部分场景在代码中发生了异常时,需要回滚事务,而不发生异常时则提交事务,从而保证数据库数据的一致性。
从这点出发,Spring给了一个约定,如果使用的是声明式事务&#