背景
你使用 springboot 和 mybatis/mybatis plus 来进行 web 开发,但是你发现你需要使用到事务操作
前置环境准备
首先你得在 application.yml 中配置好 mysql 数据源,这个我在其他博文中有写
然后你得在 application.yml 中配置好 mybatis 配置,这个我在其他博文中有写
关于 configuration 代码
通常来说,常规业务开发中,application.yml 中配置了一个 mysql 数据源,也配置 mybatis 的常规配置即可,然后想要开启事务操作可以直接在 service 指定方法上方加上 @Transactionl 即可让此方法开通事物操作了,而不用去自定义 Configuration 来配置事物操作
如果你要自定义也可以,或者如果你使用多 mysql 多个数据源,你可能会在 application.yml 中配置多个 mysql 数据源,那么你就需要指定哪个数据源对应哪个事物操作 transactionManager 了,具体看下面代码
// 数据源 1 对应的配置
@Configuration
@EnableTransactionManagement
@MapperScan(basePackages = "com.example.primary.mapper", sqlSessionFactoryRef = "primarySqlSessionFactory")
public class PrimaryDataSourceConfig {
@Primary
@Bean(name = "primaryDataSource")
@ConfigurationProperties(prefix = "spring.datasource.primary")
public DataSource primaryDataSource() {
return DataSourceBuilder.create().build();
}
@Primary
@Bean(name = "primarySqlSessionFactory")
public SqlSessionFactory primarySqlSessionFactory(@Qualifier("primaryDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean sessionFactoryBe