IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Springboot中使用Mybatis时,如果配置多数据源时,如何使用配置文件(.yml/.properties)中的mybatis相关配置 -> 正文阅读

[Java知识库]Springboot中使用Mybatis时,如果配置多数据源时,如何使用配置文件(.yml/.properties)中的mybatis相关配置

一般情况下,我们在springboot中配置mybatis的多数据源时,会使用下面的方法:

@Configuration
@MapperScan(basePackages = "com.example.demo.mapper",sqlSessionFactoryRef = "ssf1")
public class Sql1Config {

    @Bean(name = "ds1")
    @Primary
    @ConfigurationProperties(prefix = "sql1")
    public DruidDataSource getDataSource() {
        return new DruidDataSource();
    }

    @Bean(name = "ssf1")
    @Primary
    public SqlSessionFactory sqlSessionFactory(@Qualifier("ds1") DataSource datasource) throws Exception {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        sqlSessionFactoryBean.setDataSource(datasource);
        return sqlSessionFactoryBean.getObject();
    }

}

这样做,是用我们自己手动去创建DataSource和SqlSessionFactory的bean,来替代mybatis-spring-boot-starter自动创建的bean。其中,SqlSessionFactory是mybatis用来创建SqlSession的b类。由于一个SqlSessionFactory和DataSource一一对应,因此我们两个数据源有两个DataSource的bean,因此SqlSessionFactory的bean也需要创建两个。

我们一旦手动创建了SqlSessionFactory,mybatis-spring-boot-starter就不会自动创建bean了。从起源码中可以看出来:

@org.springframework.context.annotation.Configuration
@ConditionalOnClass({ SqlSessionFactory.class, SqlSessionFactoryBean.class })
@ConditionalOnBean(DataSource.class)
@EnableConfigurationProperties(MybatisProperties.class)
@AutoConfigureAfter(DataSourceAutoConfiguration.class)
public class MybatisAutoConfiguration {

     ...
  @Bean
  @ConditionalOnMissingBean
  public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception { 
     ...
  }
  
  ...
}

由于@ConditionalOnMissingBean注解的作用,如果spring的bean清单中有SqlSessionFactory,就不会自动创建SqlSessionFactory的bean。

而yml中mybatis相关配置是在mybatis-spring-boot-starter自动创建bean时注入给bean的,因此我们手动创建的bean,并不会从yml中读取相关配置。我们需要手动将配置注入进去,而注入方法其实很简单:

@Configuration
@MapperScan(basePackages = "com.example.demo.dao",sqlSessionFactoryRef = "ssf1")
public class Sql1Config {

    Logger logger = LoggerFactory.getLogger(this.getClass());

    @Bean(name = "ds1")
    @Primary 
    @ConfigurationProperties(prefix = "mybatis")//加上该注解
    public DruidDataSource getDataSource() {
        return new DruidDataSource();
    }

    @Bean(name = "ssf1")
    @Primary
    @ConfigurationProperties(prefix = "mybatis")
    public SqlSessionFactory sqlSessionFactory(@Qualifier("ds1") DataSource datasource) throws Exception {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        sqlSessionFactoryBean.setDataSource(datasource);
        return sqlSessionFactoryBean.getObject();
    }

}

使用 @ConfigurationProperties(prefix = "mybatis") 注解即可。配置文件中mybatis前缀的配置会注入给SqlSessionFactory对象。但是要注意,配置文件中的properties键值对要和mybatis原生保持一致。否则就只能使用?ConfigurationCustomizer或者SqlSessionFactoryBean.setConfiuration(xxx)来实现配置注入了。

如果有给不同数据源的mybatis注入不同配置,也很简单,使用不同的前缀即可,然后

@ConfigurationProperties(prefix = "你的前缀")即可。但是还是要保证每一段配置的键值对和mybatis原生键值对一致,spring框架才能帮我们注入对应的属性。

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-08-12 16:28:00  更:2021-08-12 16:30:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/18 7:01:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码