记录一下通过线程对数据库同时进行查询以增加效率

       //线程数量:3
       CountDownLatch latch = new CountDownLatch(3);
        ExecutorService threadPool = Executors.newFixedThreadPool(3);
        List<Future<List<Map<String,Object>>>> futureTaskList = new ArrayList<Future<List<Map<String,Object>>>>(3);

        futureTaskList.add(threadPool.submit(new Callable<List<Map<String,Object>>>() {
            @Override
                public List<Map<String,Object>> call() throws Exception {
                    //到库统计
                    List<Map<String,Object>> list =  inTrainMapper.countDK(params);
                    latch.countDown();
                    return list;
                }
        }));

        futureTaskList.add(threadPool.submit(new Callable<List<Map<String,Object>>>() {
            @Override
            public List<Map<String,Object>> call() throws Exception {
                //多式联运统计
                List<Map<String,Object>> list = inTrainMapper.countLY(params);
                latch.countDown();
                return list;
            }
        }));

        futureTaskList.add(threadPool.submit(new Callable<List<Map<String,Object>>>() {
            @Override
            public List<Map<String,Object>> call() throws Exception {
                //未出库统计
                List<Map<String,Object>> list = unTrain(params);
                latch.countDown();
                return list;
            }
        }));

//拿到三次查询返回的listMap
        List<Map<String, Object>> list1 = new ArrayList<>();
        List<Map<String, Object>> list2 = new ArrayList<>();
        List<Map<String, Object>> list3 = new ArrayList<>();
        try {
            list1 =  futureTaskList.get(0).get();
            list2 = futureTaskList.get(1).get();
            list3 = futureTaskList.get(2).get();
        } catch (InterruptedException e) {
            e.printStackTrace();
        } catch (ExecutionException e) {
            e.printStackTrace();
        }

你可能感兴趣的:(记录一下通过线程对数据库同时进行查询以增加效率)