/** * Copyright 2018-2020 stylefeng & fengshuonan (sn93@qq.com) *
* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at *
* http://www.apache.org/licenses/LICENSE-2.0 *
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package cn.stylefeng.guns.config.datasource;
import cn.stylefeng.guns.base.db.collector.SqlSessionFactoryCreator;
import cn.stylefeng.guns.base.db.context.DataSourceContext;
import cn.stylefeng.guns.base.db.context.SqlSessionFactoryContext;
import cn.stylefeng.guns.base.db.exception.DataSourceInitException;
import cn.stylefeng.roses.core.config.properties.DruidProperties;
import cn.stylefeng.roses.core.mutidatasource.mybatis.OptionalSqlSessionTemplate;
import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.session.SqlSessionFactory;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.context.annotation.Primary;
import javax.sql.DataSource;
import static cn.stylefeng.guns.base.db.context.DataSourceContext.MASTER_DATASOURCE_NAME;
/**
* 多数据源配置
*
* 注:由于引入多数据源,所以让spring事务的aop要在多数据源切换aop的后面 * * @author stylefeng * @Date 2017/5/20 21:58 */ @Slf4j @Configuration @Import(SqlSessionFactoryCreator.class) public class SqlSessionFactoryConfig { /** * 主sqlSessionFactory */ @Primary @Bean public SqlSessionFactory sqlSessionFactoryPrimary(@Qualifier("dataSourcePrimary") DataSource dataSource, SqlSessionFactoryCreator sqlSessionFactoryCreator) { return sqlSessionFactoryCreator.createSqlSessionFactory(dataSource); } /** * 多数据源sqlSessionTemplate切换模板 */ @Bean(name = "gunsSqlSessionTemplate") public OptionalSqlSessionTemplate gunsSqlSessionTemplate(@Qualifier("dataSourcePrimary") DataSource dataSourcePrimary, @Qualifier("sqlSessionFactoryPrimary") SqlSessionFactory sqlSessionFactoryPrimary, SqlSessionFactoryCreator sqlSessionFactoryCreator, DruidProperties druidProperties) { //初始化数据源容器 try { DataSourceContext.initDataSource(druidProperties, dataSourcePrimary); } catch (Exception e) { log.error("初始化数据源容器错误!", e); throw new DataSourceInitException(DataSourceInitException.ExEnum.INIT_DATA_SOURCE_ERROR); } //添加主数据源的SqlSessionFactory SqlSessionFactoryContext.addSqlSessionFactory(MASTER_DATASOURCE_NAME, sqlSessionFactoryPrimary); //初始化其他数据源的SqlSessionFactory的容器 SqlSessionFactoryContext.initBaseSqlSessionFactory(sqlSessionFactoryCreator); //设置SqlHelper为主数据源 SqlHelper.FACTORY = sqlSessionFactoryPrimary; return new OptionalSqlSessionTemplate(sqlSessionFactoryPrimary, SqlSessionFactoryContext.getSqlSessionFactorys()); } }