场景:表B依赖表A新增的数据,表A中新增数据,增加完之后,再把数据放到表B中,为了避免页面的长时间卡顿,在表A中新增数据时候用到了completefuture,或者其他的异步方式(开启线程等)。功能之前是采用同步的,没有什么问题,用了异步后,出现问题是,表A新增的数据同步不到表B了,插入表A数据的操作开启异步之后,数据可能还没有插入完成,主线程直接往下走到查询表A新增数据同步表B的操作了,此时可能表A里面并没有数据。
解决方案:
- 查询表A数据的操作,启用一个定时任务,按一定频率去查询,查询到有数据了,就执行同步表B,如上图C
- 把同步表B的操作也放到,表A新增数据的异步线程后面,如上图D
因为表A新增数据的异步操作是在平台提供的代码,不可修改,所以采用了解决方案1