复杂业务中,统一处理多表操作
程序员文章站
2024-03-21 12:13:58
...
业务背景
在一个复杂的后台业务处理中,总是会出现通过各种逻辑处理过程中,产生对很多表的增删改操作、调用其他模块接口、消息队列等,如果直接边处理边对表修改,则@Transactional事务管理的范围就很大,需要对很多方法添加该注释,为了让事务管理的范围尽量减小,就将所有的需要的操作全部缓存起来,再统一处理。
处理思路
我使用的map<Emun,Collection<T>> 局部变量的方式缓存起来,在分析需求的时候,已经明确了业务会对哪些数据造成变化,使用枚举定义出来,作为map的key,value就是需要对应的表或者消息的内容。
主要代码
增加一条处理记录
调用方法 addElement(map, [key], (T) [element]);
/**
* 数据集合中新增元素
*
* @param map 数据集合
* @param key
* @param element 新元素
* @param <T>
*/
private <T> void addElement(Map<TableEm, List<T>> map, TableEm key, T element) {
if (null == element) {
return;
}
List<T> ts = map.get(key);
if (null == ts) {
List<T> newTs = new ArrayList<>();
newTs.add(element);
map.put(key, newTs);
} else {
ts.add(element);
map.put(key, ts);
}
}
查重,去重
由于我的业务存在不同的业务会影响同一个表的问题,我的业务唯一健都是recordId,调用方法 ([element]) getElement(map, [key], [primary_key])
private static <T> T getElement(Map<String, List<T>> map, String key, String recordId) {
List<T> ts = map.get(key);
if (null == ts || ts.isEmpty()) {
return null;
}
for (T t : ts) {
Class<?> aClass = t.getClass();
try {
Method getRecordIdMethod = aClass.getMethod("getRecordId");
Object id = getRecordIdMethod.invoke(t);
if (recordId.equals(id.toString())) {
return t;
}
} catch (NoSuchMethodException | IllegalAccessException | InvocationTargetException e) {
return null;
}
}
return null;
}
统一处理
按前面方法统一获取到之后,统一在一个方法内,注解@Transacal遍历处理map即可;
这种方式,业务处理较为清晰,便于维护,但不知道是否存在其他问题?
上一篇: LVS详解(DR模式和NAT模式的配置)