做报表查询开发的时候经常遇到依次查询很多表的操作,导致频繁访问数据库,生成报表的速度非常慢。
这里分享实际工作中一个运用多线程优化查询速度的示例
1,如代码,创建了3个线程,同时去查询我所需要的数据,然后把数据存起来后续使用,三个线程都执行完毕后才会结束下面这段代码。
protected Map<String, String> getData(IFormView view) {
logger.error("当前数据生成器为" + this.getClass().getName());
Map<String, String> data = new ConcurrentHashMap<>();
//根据卡片数量,设置线程池及扣减数量,执行多线程任务
ThreadPool pool = ThreadPools.newCachedThreadPool(view.getPageId(), 3, 6);
CountDownLatch countDownLatch = new CountDownLatch(3);
try {
pool.execute(() -> {
getSpData(view, data);
countDownLatch.countDown();
});
pool.execute(() -> {
getKpData(view, data);
countDownLatch.countDown();
});
pool.execute(() -> {
getPjclData(view, data);
countDownLatch.countDown();
});
boolean await = countDownLatch.await(60, TimeUnit.SECONDS);
if (!await) {
view.showTipNotification("数据请求时间过长,部分数据请求失败!");
}
} catch (Exception e) {
throw new RuntimeException(e);
} finally {
pool.close();
}
return data;
}