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

相关推荐
黑客学长-刘备几秒前
终于有人把网络安全就业方向一口气讲清了(非常详细)零基础入门到精通,收藏这一篇就够了
java·运维·服务器·网络·python·安全·web安全
小爬虫程序猿1 分钟前
Java爬虫:在1688上“照片快递”上传图片
java·开发语言·爬虫
Json_181790144802 分钟前
小红书笔记详情API接口系列(概述到示例案例)
开发语言·python
热爱生活热爱你23 分钟前
Qt5 读写共享内存,已验证,支持汉字的正确写入和读取
开发语言·qt
大G哥28 分钟前
MyBatis 源码分析 - SQL执行过程(三)之 ResultSetHandler
数据库·sql·microsoft·mybatis
QEasyCloud20221 小时前
简道云和企业微信数据同步集成案例
java·大数据·前端
TheoBrien1 小时前
JUC(java.util.concurrent) 的常⻅类
java·开发语言
淡淡蛋痛1 小时前
D3.js 入门指南
开发语言·javascript·信息可视化
wrx繁星点点1 小时前
创建型模式-建造者模式:构建复杂对象的优雅解决方案
java·开发语言·数据结构·数据库·spring·maven·建造者模式
王大锤43911 小时前
golang的多表联合orm
开发语言·后端·golang