一个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

相关推荐
FG.4 分钟前
Day22
java·面试
apihz4 分钟前
域名WHOIS信息查询免费API使用指南
android·开发语言·数据库·网络协议·tcp/ip
菜鸟的迷茫6 分钟前
Redis 缓存雪崩、穿透、击穿面试题深度解析与 Spring Boot 实战代码示例
java
珹洺17 分钟前
C++算法竞赛篇:DevC++ 如何进行debug调试
java·c++·算法
coding随想18 分钟前
掌控网页的魔法之书:JavaScript DOM的奇幻之旅
开发语言·javascript·ecmascript
SHUIPING_YANG24 分钟前
根据用户id自动切换表查询
java·服务器·数据库
爱吃烤鸡翅的酸菜鱼36 分钟前
IDEA高效开发:Database Navigator插件安装与核心使用指南
java·开发语言·数据库·编辑器·intellij-idea·database
惊涛骇浪、42 分钟前
SpringMVC + Tomcat10
java·tomcat·springmvc
墨染点香1 小时前
LeetCode Hot100【6. Z 字形变换】
java·算法·leetcode
心情好的小球藻1 小时前
Python应用进阶DAY9--类型注解Type Hinting
开发语言·python