背景
我们公司的系统中有一个业务场景,需要第三方的账户数据同步到我们系统。
同步账号的同时,会将所有同步数据和是否成功记录到一张同步日志表中,方便排查问题和记录。
好了,话不多说,我们直接上代码。
目前的代码
下面是一段伪代码
java复制代码@Data
@Build
public class Test() {
private boolean success = true;
}
@Transaction
public void sync() {
Test test = Test.builder().build();
try{
xxxxx
}catch(Exception e) {
log.error("xxxx",e)
test.setSuccess(false);
throw new ThirdAccountException("同步账号错误:" + e.getMessage());
} finally {
testMapper.insert(test);
}
}
大家能看出来这段代码有什么问题吗?
talk is cheap, show me the code
直接实战演示
数据库新建 账户数据同步记录表
sql复制代码CREATE TABLE `account_log` (
`id` bigint NOT NULL,
`data` varchar(255) DEFAULT NULL COMMENT '第三方数据',
`success` tinyint(1) DEFAULT NULL COMMENT '是否成功0否1是',
`error_msg` varchar(255) DEFAULT NULL COMMENT '错误信息',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
第三方账户数据实体
java复制代码package com.fandf.demo.transaction;
import cn.hutool.json.JSONUtil;
import io.swagger.annotations.ApiModel;
import lombok.AllArgsConstructor;
import lombok.Data;
/**
* @author fandongfeng
* @date 2023/6/17 14:45
*/
@Data
@AllArgsConstructor(staticName = "of")
@ApiModel("第三方数据实体")
public class ThirdAccount {
private String id;
private String data;
public AccountLog toAccountLog() {
return AccountLog.builder().data(JSONUtil.toJsonStr(this)).build();
}
}
本地账户同步记录实体
java复制代码package com.fandf.demo.transaction;
import c