wisdomisite-java/src/main/java/com/zhgd/config/DataSourceOneConfig.java

81 lines
3.4 KiB
Java
Raw Normal View History

2024-04-01 13:45:32 +08:00
package com.zhgd.config;
2024-04-18 20:05:24 +08:00
import com.baomidou.mybatisplus.annotation.DbType;
2024-04-01 13:45:32 +08:00
import com.baomidou.mybatisplus.core.MybatisConfiguration;
2024-04-18 20:05:24 +08:00
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
2024-04-01 13:45:32 +08:00
import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean;
2024-04-23 20:01:26 +08:00
import com.zhgd.mybatis.DataScopeHandler;
import com.zhgd.mybatis.DataScopeInterceptor;
2024-04-01 13:45:32 +08:00
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionTemplate;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
2024-04-23 20:01:26 +08:00
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
2024-04-01 13:45:32 +08:00
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.jdbc.DataSourceBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Lazy;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import javax.sql.DataSource;
@Configuration
@MapperScan(basePackages = {"com.zhgd.*.*.*.*.mapper", "com.zhgd.*.*.*.mapper"}, sqlSessionTemplateRef = "db1SqlSessionTemplate")
public class DataSourceOneConfig {
@Bean
@ConfigurationProperties(prefix = "spring.datasource.db1")
public DataSource db1DataSource() {
return DataSourceBuilder.create().build();
}
2024-07-19 18:26:48 +08:00
/**
* 这个是懒加载的注解根据自己项目需要看是否添加
* @param dataSource
* @return
* @throws Exception
*/
2024-04-01 13:45:32 +08:00
@Bean
2024-07-19 18:26:48 +08:00
@Lazy
2024-04-01 13:45:32 +08:00
public SqlSessionFactory db1SqlSessionFactory(@Qualifier("db1DataSource") DataSource dataSource) throws Exception {
MybatisSqlSessionFactoryBean bean = new MybatisSqlSessionFactoryBean();
bean.setDataSource(dataSource);
//开启驼峰
MybatisConfiguration configuration = new MybatisConfiguration();
configuration.setMapUnderscoreToCamelCase(true);
2024-06-01 14:37:49 +08:00
configuration.setLogImpl(StdOutImplCustom.class);
2024-04-01 13:45:32 +08:00
bean.setConfiguration(configuration);
bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:com/zhgd/xmgl/**/*.xml"));
2024-04-18 20:05:24 +08:00
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
2024-04-23 20:01:26 +08:00
DataScopeInterceptor dataScopeInterceptor = new DataScopeInterceptor();
dataScopeInterceptor.setDataScopeHandler(dataScopeHandler());
interceptor.addInnerInterceptor(dataScopeInterceptor);
2024-04-18 20:05:24 +08:00
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
bean.setPlugins(interceptor);
2024-04-01 13:45:32 +08:00
return bean.getObject();
}
2024-04-23 20:01:26 +08:00
@Bean
@ConditionalOnMissingBean
public DataScopeHandler dataScopeHandler() {
return new DataScopeHandler();
}
2024-04-01 13:45:32 +08:00
@Bean
@Primary
public DataSourceTransactionManager db1TransactionManager(@Qualifier("db1DataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
@Bean
@Primary
@Lazy
public SqlSessionTemplate db1SqlSessionTemplate(@Qualifier("db1SqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
return new SqlSessionTemplate(sqlSessionFactory);
}
}