一个transitional中操作两个不同的数据源的service

问题

问题就是使用了transitional注解之后会让DS注解失效。

解决办法

业务逻辑主入口这里正常使用@Transactional注解。

java 复制代码
package org.springblade.wlw.service.impl;

import com.baomidou.dynamic.datasource.annotation.DS;
import org.springblade.wlw.pojo.entity.waterdata.WaterDevice;
import org.springblade.wlw.pojo.entity.waterdata.WaterDistanceDeviceEx;
import org.springblade.wlw.pojo.vo.WaterDistanceDevice;
import org.springblade.wlw.service.IWaterDeviceService;
import org.springblade.wlw.service.IWaterDistanceDeviceExService;
import org.springblade.wlw.service.IWaterDistanceDeviceService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;

@Service
public class WaterDistanceDeviceServiceImpl implements IWaterDistanceDeviceService {
	@Autowired
	private IWaterDeviceService waterDeviceService;
	@Autowired
	private IWaterDistanceDeviceExService waterDistanceDeviceExService;

	@Override
	@Transactional(propagation = Propagation.REQUIRED)
	public void insertFullRecored(WaterDistanceDevice waterDistanceDevice) {
		WaterDevice waterDevice = WaterDevice.fromWaterDistanceDevice(waterDistanceDevice);
		WaterDistanceDeviceEx deviceEx = WaterDistanceDeviceEx.fromWaterDistanceDevice(waterDistanceDevice);
		if (waterDevice == null || deviceEx == null) {
			return;
		}
		waterDeviceService.insertFullRecored(waterDevice);
		waterDistanceDeviceExService.insertFullRecored(deviceEx);
	}
}

两个单独的service也要声明事务,不过要指定为Propagation.REQUIRED_NEW. 每个Service上面要通过@DS注解指定数据源(这是一个正常的操作). 个人的一个建议:DS注解要么全部声明在service类上面, 要么全部生命在mapper接口上面, 避免到处都是。 虽然DS可以声明在方法上面, 但是还是避免吧,最好就是一个service控制一张表,是对一个表的增删改查, 没有必要声明在方法上面。

java 复制代码
	@Override
	@Transactional(propagation = Propagation.REQUIRES_NEW)
	public void insertFullRecored(WaterDevice device) {
		this.waterDeviceMapper.insertFullRecord(device);
	}
java 复制代码
	@Override
	@Transactional(propagation = Propagation.REQUIRES_NEW)
	public void insertFullRecored(WaterDistanceDeviceEx deviceEx) {
		this.waterDistanceDeviceExMapper.insertFullRecord(deviceEx);
	}

参考

1\] https://blog.csdn.net/qq_16159433/article/details/120951554

相关推荐
lUie INGA1 小时前
在2023idea中如何创建SpringBoot
java·spring boot·后端
小糖学代码1 小时前
LLM系列:1.python入门:15.JSON 数据处理与操作
开发语言·python·json·aigc
handler012 小时前
从源码到二进制:深度拆解 Linux 下 C 程序的编译与链接全流程
linux·c语言·开发语言·c++·笔记·学习
geBR OTTE2 小时前
SpringBoot中整合ONLYOFFICE在线编辑
java·spring boot·后端
Porunarufu2 小时前
博客系统UI自动化测试报告
java
小白学大数据2 小时前
现代Python爬虫开发范式:基于Asyncio的高可用架构实战
开发语言·爬虫·python·架构
渔舟小调2 小时前
P19 | 前端加密通信层 pikachuNetwork.js 完整实现
开发语言·前端·javascript
不爱吃炸鸡柳2 小时前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构
网络安全许木2 小时前
自学渗透测试第21天(基础命令复盘与DVWA熟悉)
开发语言·网络安全·渗透测试·php
t***5442 小时前
如何在Dev-C++中使用Clang编译器
开发语言·c++