【第九章】 springboot + mybatis + 多数据源 (AOP实现)
2017-07-13 13:37
701 查看
在第八章 springboot + mybatis + 多数据源代码的基础上,做两点修改
1、ShopDao
package com.xxx.firstboot.common.datasource; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.stereotype.Component; import com.xxx.firstboot.dao.ShopDao; @Aspect @Component public class DataSourceAspect { /** * 使用空方法定义切点表达式 */ @Pointcut("execution(* com.xxx.firstboot.dao.*.*(..))") public void declareJointPointExpression() { } /** * 使用定义切点表达式的方法进行切点表达式的引入 */ @Before("declareJointPointExpression()") public void setDataSourceKey(JoinPoint point) { // 连接点所属的类实例是ShopDao if (point.getTarget() instanceof ShopDao) { DatabaseContextHolder.setDatabaseType(DatabaseType.mytestdb2); } else {// 连接点所属的类实例是UserDao(当然,这一步也可以不写,因为defaultTargertDataSource就是该类所用的mytestdb) DatabaseContextHolder.setDatabaseType(DatabaseType.mytestdb); } } }View Code
注意:该切点表达式也可以用在其他切面类中,引入的时候使用"全类名.切点方法名()",例:@Before("com.xxx.firstboot.common.datasource.DataSourceAspect.declareJointPointExpression()")
相关文章推荐
- 第九章 springboot + mybatis + 多数据源 (AOP实现)
- 第九章 springboot + mybatis + 多数据源 (AOP实现)
- springboot + mybatis + 多数据源 (AOP实现)
- 基于Mybatis+Spring+SpringAOP实现Mybatis多数据源切换
- Springboot+Mybatis+Druid 实现多数据源,与事务管理
- Springboot+Mybatis+Pagehelper+Aop动态配置Oracle、Mysql数据源
- Spring Boot 整合 Mybatis 实现 Druid 多数据源详解
- Spring Boot 整合 Mybatis 实现 Druid 多数据源详解
- SpringBoot + Mybatis plus 实现多数据源整合
- Spring Boot+Mybatis+Druid+PageHelper实现多数据源并分页的方法
- Spring Boot 整合mybatis 使用多数据源的实现方法
- SpringBoot AOP方式实现多数据源切换的方法
- Spring Boot 集成Mybatis实现主从(多数据源)分离方案示例
- springboot+mybatis实现动态切换数据源
- Spring Boot 集成Mybatis实现主从(多数据源)分离方案
- Springboot整合Mybatis实现Druid多数据源
- Springboot+Mybatis+Maven+Oracle+Cassandra+事务(Aop)+定时任务实现
- SpringBoot+Mybatis+ Druid+PageHelper 实现多数据源并分页
- Spring boot +Mybatis 实现多数据源(一:最简单版本)