50 lines
2.2 KiB
Java
50 lines
2.2 KiB
Java
package quant.rich.emoney.config;
|
|
|
|
import javax.sql.DataSource;
|
|
|
|
import org.apache.ibatis.session.SqlSessionFactory;
|
|
import org.mybatis.spring.SqlSessionTemplate;
|
|
import org.mybatis.spring.annotation.MapperScan;
|
|
import org.springframework.beans.factory.annotation.Qualifier;
|
|
import org.springframework.context.annotation.Bean;
|
|
import org.springframework.context.annotation.Configuration;
|
|
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
|
|
|
|
import com.baomidou.mybatisplus.annotation.DbType;
|
|
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
|
|
import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
|
|
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
|
|
import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean;
|
|
|
|
@Configuration
|
|
@MapperScan(basePackages = "quant.rich.emoney.mapper.sqlite", sqlSessionTemplateRef = "sqliteSqlSessionTemplate")
|
|
public class SqliteMybatisConfig {
|
|
|
|
public static final String SQLITE_TRANSACTION_MANAGER = "sqliteTransactionManager";
|
|
|
|
@Bean("sqliteSqlSessionFactory")
|
|
public SqlSessionFactory sqliteSqlSessionFactory(
|
|
@Qualifier("sqliteDataSource") DataSource dataSource) throws Exception {
|
|
MybatisSqlSessionFactoryBean factory = new MybatisSqlSessionFactoryBean();
|
|
factory.setDataSource(dataSource);
|
|
|
|
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
|
|
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.SQLITE));
|
|
interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
|
|
factory.setPlugins(interceptor);
|
|
|
|
return factory.getObject();
|
|
|
|
}
|
|
|
|
@Bean("sqliteSqlSessionTemplate")
|
|
public SqlSessionTemplate sqliteSqlSessionTemplate(@Qualifier("sqliteSqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
|
|
return new SqlSessionTemplate(sqlSessionFactory);
|
|
}
|
|
|
|
@Bean("sqliteTransactionManager")
|
|
public DataSourceTransactionManager postgreTransacetionManager(@Qualifier("sqliteDataSource") DataSource dataSource) {
|
|
return new DataSourceTransactionManager(dataSource);
|
|
}
|
|
}
|