package com.casic.config; import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.mybatis.spring.SqlSessionTemplate; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import org.springframework.jdbc.datasource.DriverManagerDataSource; import javax.sql.DataSource; /** * @program: * @description: 数据库配置3 * @author: cz * @create: 2022-08-17 09:03 **/ @Configuration @MapperScan(basePackages = "com.casic.dao.spantilt",sqlSessionFactoryRef = "tiltSqlSessionFactory") public class TiltDataSourceConfig { @Value("${spring.datasource.spantilt.driver-class-name}") String driverClass; @Value("${spring.datasource.spantilt.url}") String url; @Value("${spring.datasource.spantilt.username}") String userName; @Value("${spring.datasource.spantilt.password}") String passWord; @Bean(name = "tiltDataSource") @ConfigurationProperties("spring.datasource.spantilt") public DataSource masterDataSource(){ DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setDriverClassName(driverClass); dataSource.setUrl(url); dataSource.setUsername(userName); dataSource.setPassword(passWord); return dataSource; } @Bean(name = "tiltSqlSessionFactory") public SqlSessionFactory sqlSessionFactory(@Qualifier("tiltDataSource") DataSource dataSource) throws Exception { SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean(); sessionFactoryBean.setDataSource(dataSource); sessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver() .getResources("classpath:mapper/tilt/*.xml")); return sessionFactoryBean.getObject(); } @Bean(name = "tiltSqlSessionTemplate") public SqlSessionTemplate sqlSessionFactoryTemplate(@Qualifier("tiltSqlSessionFactory") SqlSessionFactory sqlSessionFactory ) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); } }