mybatis多数据源踩坑(@DS失效?调用本类方法时失效)

在同service下,可以写两个不同的DS(“db”)注解,但是不能本类调用(会读不到DS注解,我猜测)

看官方文档说是在方法上和类上都可以用

解决方案一(贴近原来的写法)

例如,想连两个数据库的内容。
业务逻辑的service下,

    @Autowired
    private ICaseinfoService db3Service;//这个接口的实现类里写方法,带上注解指定数据库db3
    
    @Autowired
    private ICaseInfoService db1Service;//这个接口的实现类里写方法,带上注解指定数据库db1
    
    private void sqlToMysql() {
        List<Caseinfo> caseInfos = db3Service.getCaseInfo();//从数据库3查
        Integer count = db1Service.insertCaseInfo(caseInfos);//插入到数据库1
        log.info("本次插入数据{}条", count);
    }

读数据源的service下

@Service
public class CaseInfoServiceImpl extends ServiceImpl<CaseInfoMapper, CaseInfo> implements ICaseInfoService {
    @Autowired
    private CaseInfoMapper db1CaseInfoMapper;

    @DS("db1")
    @Override
    public Integer insertCaseInfo(List<Caseinfo> caseInfos) {
    	//略
        return 1;
    }

@Service
public class CaseinfoServiceImpl extends ServiceImpl<CaseinfoMapper, Caseinfo> implements ICaseinfoService {

    @Autowired
    private CaseinfoMapper db3CaseInfoMapper;

    @DS("db3")
    @Override
    public List<Caseinfo> getCaseInfo() {
        return db3CaseInfoMapper.selectList(null);
    }
}


解决方案二(在mapper接口层上加注解)

@DS("db3")
public interface CaseinfoMapper extends BaseMapper<Caseinfo> {

}
  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值