查看: 2258|回复: 0

[Java语言] Spring Boot 整合mybatis 使用多数据源的实现方法

发表于 2018-4-16 08:00:05

前言

本篇教程偏向实战,程序猿直接copy代码加入到自己的项目中做简单的修修改改便可使用,而对于springboot以及mybatis不在此进行展开介绍,如有读者希望了解可以给我留言,并持续关注,我后续会慢慢更新。(黑色区域代码部分,安卓手机可手动向左滑动,来查看全部代码)

整合

其实整合很简单,如果是用gradle的话,在build.gradle文件里加入

  1. compile('org.mybatis.spring.boot:mybatis-spring-boot-starter:1.3.1')
复制代码

如果是用maven的话在pom.xml文件里加入


单库配置:

引入之后,默认情况下,Spring Boot会自动为我们配置好一个DataSource,它会在classpath中搜索H2、hsqldb等内存数据库的jar包,如果找到了,就会自动配置一个内存数据库的DataSource。

如果在application.yml或application.property中指定了spring.datasource.*的相关配置参数,Spring Boot就会使用该配置创建一个DataSource。

然后会自动创建使用该DataSource的SqlSessionFactoryBean以及SqlSessionTemplate。会自动扫描你的Mappers,连接到SqlSessionTemplate,并注册到Spring上下文中。

  1. spring.datasource.url=jdbc:mysql://localhost/test
  2. spring.datasource.username=dbuser
  3. spring.datasource.password=dbpass
  4. spring.datasource.driver-class-name=com.mysql.jdbc.Driver
复制代码

更多参数请查看DataSourceProperties

多库配置:

由于业务需要,项目要同时使用多个数据库进行业务开发:

首先,我们必须在application.property中自定义两个数据源的配置,一个使用first.datasource.*,另一个使用second.datasource.*,为了能使别人一眼看出连接的是什么库,可以使用数据库命名,比如user库,则可以使用user.datasource.*,在使用多数据源的时候,所有必要配置都不能省略。

  1. first.datasource.url=jdbc:mysql://localhost/first
  2. first.datasource.username=dbuser1
  3. first.datasource.password=dbpass1
  4. first.datasource.driver-class-name=com.mysql.jdbc.Driver
  5. first.datasource.type=com.alibaba.druid.pool.DruidDataSource//我用的是Druid,也可以不加用默认的
  6. second.datasource.url=jdbc:mysql://localhost/second
  7. second.datasource.username=dbuser2
  8. second.datasource.password=dbpass2
  9. second.datasource.driver-class-name=com.mysql.jdbc.Driver
  10. second.datasource.type=com.alibaba.druid.pool.DruidDataSource
复制代码

直接上代码,我的做法是将两个数据源用两个配置类创建:

  1. @Configuration
  2. @MapperScan(basePackages = {"com.user.server.dao"}, sqlSessionTemplateRef = "userSqlSessionTemplate")
  3. public class UserMybatisConfig {
  4. @Bean(name = "userDataSource")
  5. @Primary //必须加此注解,不然报错,下一个类则不需要添加
  6. @ConfigurationProperties(prefix = "first.datasource") // prefix值必须是application.properteis中对应属性的前缀
  7. public DataSource userDataSource() {
  8. return DataSourceBuilder.create().build();
  9. }
  10. @Bean
  11. public SqlSessionFactory userSqlSessionFactory(@Qualifier("userDataSource") DataSource dataSource) throws Exception {
  12. SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
  13. bean.setDataSource(dataSource);
  14. //添加XML目录
  15. ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
  16. try {
  17. bean.setMapperLocations(resolver.getResources("classpath*:com/user/server/dao/mapping/*.xml"));
  18. return bean.getObject();
  19. } catch (Exception e) {
  20. e.printStackTrace();
  21. throw new RuntimeException(e);
  22. }
  23. }
  24. @Bean
  25. public SqlSessionTemplate userSqlSessionTemplate(@Qualifier("userSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
  26. SqlSessionTemplate template = new SqlSessionTemplate(sqlSessionFactory); // 使用上面配置的Factory
  27. return template;
  28. }
  29. }
  30. @Configuration
  31. @MapperScan(basePackages = {"com.airmi.server.dao"}, sqlSessionTemplateRef = "autoTestSqlSessionTemplate")
  32. public class AutoTestMybatisConfig {
  33. @Bean
  34. @ConfigurationProperties(prefix = "autotest.datasource")
  35. public DataSource autoTestDataSource() {
  36. return DataSourceBuilder.create().build();
  37. }
  38. @Bean
  39. public SqlSessionTemplate autoTestSqlSessionTemplate(@Qualifier("autoTestSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
  40. SqlSessionTemplate template = new SqlSessionTemplate(sqlSessionFactory);
  41. return template;
  42. }
  43. @Bean
  44. public SqlSessionFactory autoTestSqlSessionFactory(@Qualifier("autoTestDataSource") DataSource dataSource) throws Exception {
  45. SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
  46. bean.setDataSource(dataSource);
  47. //添加XML目录
  48. ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
  49. try {
  50. bean.setMapperLocations(resolver.getResources("classpath*:com/airmi/server/dao/mapping/*.xml"));
  51. return bean.getObject();
  52. } catch (Exception e) {
  53. e.printStackTrace();
  54. throw new RuntimeException(e);
  55. }
  56. }
  57. }
复制代码

@Primary //该注解表示在同一个接口有多个实现类可以注入的时候,默认选择哪一个,而不是让autowire注解报错,官网要求当多个数据源时,必须指定一个datasource,另一个datasource则不用添加。

@Qualifier 根据名称进行注入,通常是在具有相同的多个类型的实例的一个注入(例如有多个DataSource类型的实例)。

  1. @MapperScan (basePackages = {"com.user.server.dao"}, sqlSessionTemplateRef = "userSqlSessionTemplate") basePackages为mapper所在的包,sqlSessionTemplateRef要引用的实例。
复制代码

user代码结构如下:

总结

以上所述是小编给大家介绍的Spring Boot 整合mybatis 使用多数据源的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对程序员之家网站的支持!



回复

使用道具 举报