同步数据不外乎两种方法:一是通过对方ERP提供的API接口直接操作数据库,二是通过中间库的形式同步数据库,可想而知最好的办法是第一种,第二种方法我们采取每一分钟读取一次的方法,会有时间误差,且开销也比较高。由于某些特殊原因我们暂且采用了第二种方法同步数据,基本流程如上图所示,要匹配供应商的数据库,把数据拿到我本地进行操作,供应商那边分出了一个中间库给我们操作,对方只提供商品的基本信息,存在四个表中,并且有一个时间表用于比较他是否更新了数据,如果他更新数据则会改变基本表中的时间戳,此时时间会比时间表中的时间大,当我们此时比较式就会查出最新的数据,抽取出来根据特定字段同步到本地数据库中。在于本地大库的数据匹配,添加上其他字段形成可以使用的展现表。
技术方面我们采用定时器方法,固定时间内抓取数据,定时器方案如下代码所示:
<span style="font-size:14px;">new Thread(){
public void run(){
Connection conn = null;