利用spring aop实现数据源的切换

本文介绍如何使用 Spring AOP 和 AbstractRoutingDataSource 实现动态数据源切换。通过配置不同的切面,根据 DAO 所在包名选择对应的数据源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近项目中使用了数据库分库,所以用到了用到了数据源切换。写了一个简单的demo,供参考。

数据源切换的原理,采用的spring的aop和AbstractRoutingDataSource。

RoutingDataSource.java

DataSourceHolder.java

DAOAdvice.java

说明:RoutingDataSource类通过<bean id="dataSource" class="org.pay.common.RoutingDataSource"> 注入,在DAOAdvice类中设置的datasource的key来获得哪个数据源,DAOAdvice类根据

<aop:config proxy-target-class="true">
        <aop:advisor pointcut="execution(* org.pay.dao..*.*(..))"
            advice-ref="daoAdvice" order="100"/>

这个切面判断dao所在的package来判断使用哪个数据源将其设置到上下文根中(DataSourceHolder),

例如当org.pay.dao中的dao被调用时,取到的是dataSourceTest这个数据源

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值