Java 数据在动态增加 分页_springboot多数据源动态切换和自定义mybatis分页插件

1、配置多数据源增加druid依赖完整pom文件数据源配置文件route.datasource.driver-class-name=com.mysql.jdbc.Driverroute.datasource.url= jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8route.datasource...
摘要由CSDN通过智能技术生成

1、配置多数据源

增加druid依赖

69ed034763c15c74e3afa27907b72bbb.png

完整pom文件

数据源配置文件

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

route.datasource.driver-class-name=com.mysql.jdbc.Driver

route.datasource.url= jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8

route.datasource.username=root

route.datasource.password= 123456operate.datasource.driver-class-name=com.mysql.jdbc.Driver

operate.datasource.url= jdbc:mysql://localhost:3306/test2?useUnicode=true&characterEncoding=utf8

operate.datasource.username=root

operate.datasource.password= 123456

multiple-datasource.properties

初始化数据源

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

/*** 多数据源配置

*@authorzhouliang

* @date 2017年9月20日*/@Configuration

@PropertySource("classpath:multiple-datasource.properties")public classMyBatisConfig {

@AutowiredprivateEnvironment env;

@Autowired MybatisSpringPageInterceptor inteceptor;/*** 创建数据源(数据源的名称:方法名可以取为XXXDataSource(),XXX为数据库名称,该名称也就是数据源的名称)*/@Beanpublic DataSource operateDataSource() throwsException {

Properties props= newProperties();

props.put("driverClassName", env.getProperty("operate.datasource.driver-class-name"));

props.put("url", env.getProperty("operate.datasource.url"));

props.put("username", env.getProperty("operate.datasource.username"));

props.put("password", env.getProperty("operate.datasource.password"));returnDruidDataSourceFactory.createDataSource(props);

}

@Beanpublic DataSource routeDataSource() throwsException {

Properties props= newProperties();

props.put("driverClassName", env.getProperty("route.datasource.driver-class-name"));

props.put("url", env.getProperty("route.datasource.url"));

props.put("username", env.getProperty("route.datasource.username"));

props.put("password", env.getProperty("route.datasource.password"));returnDruidDataSourceFactory.createDataSource(props);

}/*** @Primary 该注解表示在同一个接口有多个实现类可以注入的时候,默认选择哪一个,而不是让@autowire注解报错

* @Qualifier 根据名称进行注入,通常是在具有相同的多个类型的实例的一个注入(例如有多个DataSource类型的实例)*/@Bean

@PrimarypublicDynamicDataSource dataSource(

@Qualifier("routeDataSource") DataSource routeDataSource,

@Qualifier("operateDataSource") DataSource operateDataSource) {

Map targetDataSources = new HashMap();

targetDataSources.put(DatabaseType.routeDS, routeDataSource);

targetDataSources.put(DatabaseType.operateDS, operateDataSource);

DynamicDataSource dataSource= newDynamicDataSource();

dataSource.setTargetDataSources(targetDataSources);//该方法是AbstractRoutingDataSource的方法

returndataSource;

}/*** 根据数据源创建SqlSessionFactory*/@BeanpublicSqlSessionFactory sqlSessionFactory(DynamicDataSource ds)throwsException {

SqlSessionFactoryBean fb= newSqlSessio

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值