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.

63 lines
2.7 KiB

  1. package com.example.demo.config;
  2. import com.zaxxer.hikari.HikariConfig;
  3. import com.zaxxer.hikari.HikariDataSource;
  4. import lombok.extern.slf4j.Slf4j;
  5. import org.apache.ibatis.session.SqlSessionFactory;
  6. import org.mybatis.spring.SqlSessionFactoryBean;
  7. import org.mybatis.spring.SqlSessionTemplate;
  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. public class SqlServer1DataSourceConfig {
  18. /**
  19. * 定义 SQL Server 数据源
  20. */
  21. @Bean(name = "sqlserver1DataSource")
  22. @ConfigurationProperties(prefix = "spring.datasource.sqlserver1")
  23. public DataSource sqlserver1DataSource() {
  24. log.info("Initializing SQL Server data source...");
  25. return DataSourceBuilder.create().type(HikariDataSource.class).build();
  26. }
  27. /**
  28. * 定义 SQL Server SqlSessionFactory
  29. */
  30. @Bean(name = "sqlserver1SqlSessionFactory")
  31. public SqlSessionFactory sqlserver1SqlSessionFactory(@Qualifier("sqlserver1DataSource") DataSource dataSource,
  32. @Qualifier("globalConfiguration6") org.apache.ibatis.session.Configuration globalConfiguration) throws Exception {
  33. log.info("Initializing SQL Server SqlSessionFactory...");
  34. SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
  35. sessionFactory.setDataSource(dataSource);
  36. sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:sqlserverMapper/*.xml"));
  37. sessionFactory.setConfiguration(globalConfiguration);
  38. return sessionFactory.getObject();
  39. }
  40. /**
  41. * 定义 SQL Server SqlSessionTemplate
  42. */
  43. @Bean(name = "sqlserver1SqlSessionTemplate")
  44. public SqlSessionTemplate sqlserver1SqlSessionTemplate(@Qualifier("sqlserver1SqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
  45. log.info("Initializing SQL Server SqlSessionTemplate...");
  46. return new SqlSessionTemplate(sqlSessionFactory);
  47. }
  48. /**
  49. * 定义全局 MyBatis 配置
  50. */
  51. @Bean
  52. @ConfigurationProperties(prefix = "mybatis.configuration.sqlserver1")
  53. public org.apache.ibatis.session.Configuration globalConfiguration6() {
  54. log.info("Initializing SQL Server MyBatis global configuration...");
  55. return new org.apache.ibatis.session.Configuration();
  56. }
  57. }