当前位置:   article > 正文

springboot + mybatis + sqlite 多数据源配置_org.sqlite.jdbc

org.sqlite.jdbc

一、pom依赖

  1. <dependency>
  2. <groupId>org.xerial</groupId>
  3. <artifactId>sqlite-jdbc</artifactId>
  4. <version>3.30.1</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework.boot</groupId>
  8. <artifactId>spring-boot-starter-jdbc</artifactId>
  9. </dependency>
  10. <dependency>
  11. <groupId>org.mybatis.spring.boot</groupId>
  12. <artifactId>mybatis-spring-boot-starter</artifactId>
  13. <version>2.1.2</version>
  14. </dependency>

二、yml配置

  1. spring:
  2. datasource:
  3. driver-class-name: org.sqlite.JDBC
  4. url1: jdbc:sqlite::resource:xxx.db #数据库文件在resources目录下
  5.   url2: jdbc:sqlite::resource:xxx.db
  6. url3: jdbc:sqlite::resource:xxx.db

三、启动类

  1. @SpringBootApplication(exclude = DataSourceAutoConfiguration.class)// 排除自动数据源配置
  2. public class Application {
  3. public static void main(String[] args) {
  4. SpringApplication.run(Application .class, args);
  5. }
  6. }

四、数据源配置

// 类名和bean name保持唯一性,否则会报bean name重复加载错误
  1. @Configuration
  2. @MapperScan(basePackages = {"mapper.java路径"}, sqlSessionTemplateRef = "sqlSessionTemplate1")
  3. public class DataSourceConfig1 {
  4. @Value("${spring.datasource.url1}")
  5. private String url;
  6. @Primary
  7. @Bean(name = "dataSource1")
  8. public DataSource strategyDataSource() throws SQLException {
  9. SQLiteDataSource sqLiteDataSource = new SQLiteDataSource();
  10. sqLiteDataSource.setUrl(url);
  11. sqLiteDataSource.setDatabaseName("dataSource1");
  12. SQLiteConfig config = new SQLiteConfig();
  13. config.setJournalMode(SQLiteConfig.JournalMode.OFF);// 关日志
  14. config.setSynchronous(SQLiteConfig.SynchronousMode.OFF);// 关刷新
  15. sqLiteDataSource.setConfig(config);
  16. return sqLiteDataSource;
  17. }
  18. @Bean(name = "sqlSessionFactory1")
  19. public SqlSessionFactory createSqlSessionFactoryBean(@Qualifier("dataSource1") DataSource dataSource) throws Exception {
  20. SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
  21. bean.setDataSource(dataSource);
  22. PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
  23. bean.setMapperLocations(resolver.getResources("classpath:mapper.xml路径"));
  24. bean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
  25. return bean.getObject();
  26. }
  27. @Bean(name = "sqlSessionTemplate1")
  28. public SqlSessionTemplate sqlSessionTemplate(@Qualifier("sqlSessionFactory1") SqlSessionFactory sqlSessionFactory) {
  29. return new SqlSessionTemplate(sqlSessionFactory);
  30. }
  31. }
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/704102
推荐阅读
相关标签
  

闽ICP备14008679号