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

业务背景

在一个复杂的后台业务处理中,总是会出现通过各种逻辑处理过程中,产生对很多表的增删改操作、调用其他模块接口、消息队列等,如果直接边处理边对表修改,则@Transactional事务管理的范围就很大,需要对很多方法添加该注释,为了让事务管理的范围尽量减小,就将所有的需要的操作全部缓存起来,再统一处理。

处理思路

我使用的map> 局部变量的方式缓存起来,在分析需求的时候,已经明确了业务会对哪些数据造成变化,使用枚举定义出来,作为map的key,value就是需要对应的表或者消息的内容。

主要代码

增加一条处理记录

调用方法 addElement(map, [key], (T) [element]);

    /**
     * 数据集合中新增元素
     *
     * @param map     数据集合
     * @param key     
     * @param element 新元素
     * @param 
     */
    private  void addElement(Map> map, TableEm key, T element) {
        if (null == element) {
            return;
        }
        List ts = map.get(key);
        if (null == ts) {
            List 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即可;


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

你可能感兴趣的:(java,业务逻辑提炼,java,事务)