欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

复杂业务中,统一处理多表操作

程序员文章站 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即可;


这种方式,业务处理较为清晰,便于维护,但不知道是否存在其他问题?