SpringBoot+mybatis实现多数据源支持详解编程语言
2023-06-13 09:20:45 时间
单个数据源在配置时会绑定一套mybatis配置,多个数据源时,不同的数据源绑定不同的mybatis配置就可以了,简单的思路就是让不同的数据源扫描不同的包,让不同的包下的mapper对应连接不同的数据源去处理逻辑。
业务场景假设项目底层有正常业务库和日志库,希望解决的是将项目中的一些日志单独记录到一个库里,比如用户操作记录、产品更新记录等。
说一下为什么会有这个需求:用户操作记录和产品更新记录可能很多,而实际中使用的又很少,就只是在某些页面单独展示一下操作或更新记录,绝大部分时间都在不停的做着插入操作,这时就可以把这种记录放到业务核心库外面。
1.定义多个数据源的mybatis配置application.properties mybatis.mapper-locations=mappers/*.xml mybatisLog.mapper-locations=mappersLog/*.xml ## datasource master # spring.datasource.type=com.alibaba.druid.pool.DruidDataSource spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test1?characterEncoding=UTF-8 spring.datasource.username=root spring.datasource.password=466420182 ## datasource log # spring.datasourceLog.type=com.alibaba.druid.pool.DruidDataSource spring.datasourceLog.driver-class-name=com.mysql.jdbc.Driver spring.datasourceLog.url=jdbc:mysql://localhost:3306/log?characterEncoding=UTF-8 spring.datasourceLog.username=root spring.datasourceLog.password=4664201822.定义多个数据源
@Configuration public class DatasourceConfig { @Bean(destroyMethod = "close", name = DataSources.MASTER_DB) @ConfigurationProperties(prefix = "spring.datasource") public DataSource dataSource() { return DataSourceBuilder.create().type(DruidDataSource.class).build(); @Bean(destroyMethod = "close", name = DataSources.LOG_DB) @ConfigurationProperties(prefix = "spring.datasourceLog") public DataSource dataSourceLog() { return DataSourceBuilder.create().type(DruidDataSource.class).build(); }3.分别配置多个数据源
@Configuration @MapperScan(basePackages = {"com.mmall.practice.dao"}) public class MybatisConfig { @Autowired @Qualifier(DataSources.MASTER_DB) private DataSource masterDB; @Bean @Primary @ConfigurationProperties(prefix = "mybatis") public SqlSessionFactoryBean sqlSessionFactoryBean() { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(masterDB); return sqlSessionFactoryBean; }
@Configuration @MapperScan(basePackages = {"com.mmall.practice.daoLog"}, sqlSessionFactoryRef = "logSqlSessionFactory") public class MybatisLogConfig { @Autowired @Qualifier("logDB") private DataSource logDB; @Bean(name = "logSqlSessionFactory") @ConfigurationProperties(prefix = "mybatisLog") public SqlSessionFactoryBean sqlSessionFactoryBean() { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); sqlSessionFactoryBean.setDataSource(logDB); return sqlSessionFactoryBean; }
这里需要注意两个数据源配置的差别,也是支持多数据源的关键
1)Configuration 扫描不同的前缀,取不同包下的sql对应的xml文件 2)SqlSessionFactoryBean 实例化时,默认的额外添加了 @Primary注解 3)MapperScan 扫描的不同的包,如果扫描相同的包也能做,但是还需要做额外的配置,可以自己尝试 4)不同的数据源使用不同的SqlSessionFactoryBean实例至此,不同包下面的 Mapper.java 文件就可以连接不同的数据源了。这里就不说如何去使用了,和之前正常一样去使用 Mapper.java 就可以了,只是操作的是不同的数据库。
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/15681.html
cjavamysqlxml相关文章
- springboot使用swagger2生成api文档
- springboot启动原理 通俗面试_spring高级面试题
- springboot启动原理总结_Springboot启动流程
- springboot整合mybatis @MapperScan可以不加在启动器上
- 最小可用maven+springboot 项目(无法使用外网,但是有maven私库情况)
- springboot整合mybatis(配置模式+注解模式)
- MyBatis——【第二章】mybatis动态sql(分页)
- MyBatis框架:第二章:传统mybatis的hello world 示例
- MyBatis框架:第十一章:mybatis 逆向工程
- SpringBoot官宣:正式弃用 Java 8 啦
- Springboot+druid数据库连接池使用「建议收藏」
- springboot启动方式_启动会启动仪式
- MyBatis框架:第六章:mybatis的核心配置
- SpringBoot(一) - SpringBoot 初识
- SpringBoot(五) - Java8 新特性
- MyBatis-Plus 快速开始及详测 SpringBoot 集成Mybatis-Plus
- SpringBoot-Security 具体案例、 实现安全框架、权限控制、aop切入
- springboot到底是什么_Springboot注解
- springboot jdbc template_Springboot教程
- springboot配置文件application没有生效处理方式
- SpringBoot与Redis
- SpringBoot整合MyBatis多数据源
- SpringBoot中的@Conditional注解
- [Springboot]JPA和MyBatis性能对比
- SpringBoot(一)走进Springboot的世界详解编程语言
- SpringBoot | 第九章:Mybatis-plus的集成和使用详解编程语言
- SpringBoot | 第十六章:web 应用开发详解编程语言
- 修改springboot默认的8080端口详解编程语言
- Mybatis操作MySQL存储过程实现数据库交互(mybatis调用mysql存储过程)