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.

66 lines
3.0 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.springframework.beans.factory.annotation.Qualifier;
  8. import org.springframework.boot.context.properties.ConfigurationProperties;
  9. import org.springframework.boot.jdbc.DataSourceBuilder;
  10. import org.springframework.context.annotation.Bean;
  11. import org.springframework.context.annotation.Configuration;
  12. import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
  13. import org.springframework.jdbc.datasource.DataSourceTransactionManager;
  14. import org.springframework.transaction.PlatformTransactionManager;
  15. import javax.sql.DataSource;
  16. @Slf4j
  17. @Configuration
  18. public class Mysql1DataSourceConfig {
  19. @Bean(name = "mysql1DataSource")
  20. @ConfigurationProperties(prefix = "spring.datasource.mysql1")
  21. public DataSource mysql1DataSource() {
  22. // 1. 先用 builder 创建出来
  23. HikariDataSource ds = DataSourceBuilder
  24. .create()
  25. .type(HikariDataSource.class)
  26. .build(); // 这里已经把 yml 里的 url/username/password 装好了
  27. // 2. 再补连接初始化 SQL(每次拿到连接自动执行)
  28. ds.setConnectionInitSql(
  29. "SET SESSION profiling=0,long_query_time=10,sql_mode='TRADITIONAL';");
  30. // 3. 如有需要还可继续补 ds.setMaximumPoolSize() 等
  31. return ds;
  32. // return DataSourceBuilder.create().type(HikariDataSource.class).build();
  33. }
  34. @Bean(name = "mysqlTransactionManager")
  35. public PlatformTransactionManager mysqlTransactionManager(@Qualifier("mysql1DataSource") DataSource dataSource) {
  36. return new DataSourceTransactionManager(dataSource);
  37. }
  38. @Bean(name = "mysql1SqlSessionFactory")
  39. // @Primary
  40. public SqlSessionFactory mysql1SqlSessionFactory(@Qualifier("mysql1DataSource") DataSource dataSource,
  41. @Qualifier("globalConfiguration1") org.apache.ibatis.session.Configuration globalConfiguration1) throws Exception {
  42. SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
  43. sessionFactory.setDataSource(dataSource);
  44. sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:{mapper,cashMapper}/*.xml"));
  45. sessionFactory.setConfiguration(globalConfiguration1);
  46. return sessionFactory.getObject();
  47. }
  48. @Bean(name = "mysql1SqlSessionTemplate")
  49. // @Primary
  50. public SqlSessionTemplate mysql1SqlSessionTemplate(@Qualifier("mysql1SqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
  51. return new SqlSessionTemplate(sqlSessionFactory);
  52. }
  53. @Bean
  54. @ConfigurationProperties(prefix = "mybatis.configuration.mysql1")
  55. public org.apache.ibatis.session.Configuration globalConfiguration1() {
  56. return new org.apache.ibatis.session.Configuration();
  57. }
  58. }