You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

52 lines
2.3 KiB

  1. package com.example.demo.config;
  2. import com.zaxxer.hikari.HikariDataSource;
  3. import lombok.extern.slf4j.Slf4j;
  4. import org.apache.ibatis.session.SqlSessionFactory;
  5. import org.mybatis.spring.SqlSessionFactoryBean;
  6. import org.mybatis.spring.SqlSessionTemplate;
  7. import org.mybatis.spring.annotation.MapperScan;
  8. import org.springframework.beans.factory.annotation.Qualifier;
  9. import org.springframework.boot.context.properties.ConfigurationProperties;
  10. import org.springframework.boot.jdbc.DataSourceBuilder;
  11. import org.springframework.context.annotation.Bean;
  12. import org.springframework.context.annotation.Configuration;
  13. import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
  14. import javax.sql.DataSource;
  15. @Slf4j
  16. @Configuration
  17. @MapperScan(
  18. basePackages = "com.example.demo.mapper.bean", // 扫描coin包
  19. sqlSessionTemplateRef = "mysql2SqlSessionTemplate"
  20. )
  21. public class Mysql2DataSourceConfig {
  22. @Bean(name = "mysql2DataSource")
  23. @ConfigurationProperties(prefix = "spring.datasource.mysql2")
  24. public DataSource mysql2DataSource() {
  25. return DataSourceBuilder.create().type(HikariDataSource.class).build();
  26. }
  27. @Bean(name = "mysql2SqlSessionFactory")
  28. // @Primary
  29. public SqlSessionFactory mysql2SqlSessionFactory(@Qualifier("mysql2DataSource") DataSource dataSource,
  30. @Qualifier("globalConfiguration2") org.apache.ibatis.session.Configuration globalConfiguration2) throws Exception {
  31. SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
  32. sessionFactory.setDataSource(dataSource);
  33. sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:jindouMapper/*.xml"));
  34. sessionFactory.setConfiguration(globalConfiguration2);
  35. return sessionFactory.getObject();
  36. }
  37. @Bean(name = "mysql2SqlSessionTemplate")
  38. // @Primary
  39. public SqlSessionTemplate mysql2SqlSessionTemplate(@Qualifier("mysql2SqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
  40. return new SqlSessionTemplate(sqlSessionFactory);
  41. }
  42. @Bean
  43. @ConfigurationProperties(prefix = "mybatis.configuration.mysql2")
  44. public org.apache.ibatis.session.Configuration globalConfiguration2() {
  45. return new org.apache.ibatis.session.Configuration();
  46. }
  47. }