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.context.annotation.Primary; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import org.springframework.jdbc.datasource.DriverManagerDataSource; import javax.sql.DataSource; /** * @program: * @description: 数据库配置1 * @author: cz * @create: 2022-08-17 09:03 **/ @Configuration @MapperScan(basePackages = "com.casic.dao.cms", sqlSessionFactoryRef = "cmsSqlSessionFactory") public class CmsDataSourceConfig { @Value("${spring.datasource.cms.driver-class-name}") String driverClass; @Value("${spring.datasource.cms.url}") String url; @Value("${spring.datasource.cms.username}") String userName; @Value("${spring.datasource.cms.password}") String passWord; @Primary @Bean(name = "cmsDataSource") @ConfigurationProperties("spring.datasource.cms") public DataSource masterDataSource() { DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setDriverClassName(driverClass); dataSource.setUrl(url); dataSource.setUsername(userName); dataSource.setPassword(passWord); return dataSource; } @Bean(name = "cmsSqlSessionFactory") public SqlSessionFactory sqlSessionFactory(@Qualifier("cmsDataSource") DataSource dataSource) throws Exception { SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean(); sessionFactoryBean.setDataSource(dataSource); sessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver() .getResources("classpath:mapper/cms/*.xml")); return sessionFactoryBean.getObject(); } @Bean(name = "cmsSqlSessionTemplate") public SqlSessionTemplate sqlSessionFactoryTemplate(@Qualifier("cmsSqlSessionFactory") SqlSessionFactory sqlSessionFactory ) throws Exception { return new SqlSessionTemplate(sqlSessionFactory); } }