多线程查询数据库为什么执行到查询数据库的那一步就跳出了

2019-01-02 21:34发布

ThreadPoolExecutor executor = new ThreadPoolExecutor(
corePoolSize, maximumPoolSizeSize, keepAliveTime, TimeUnit.SECONDS, workQueue
);

    System.setOut(new PrintStream(new BufferedOutputStream(
            new FileOutputStream("E:/charger/sql/out/mixdata1102.txt")), true));


    for (String siteInfo : lines) {
        executor.execute(() -> {
            String[] sites = siteInfo.split(",");
            System.err.println(Thread.currentThread().getName() + " " + sites[0]);
            // todo 按站点id查询数据 不为null的更新
            Site site = siteMapper.selectById(sites[0]);
            })
            }

标签:
1条回答
笑指拈花
2楼-- · 2019-01-02 22:03

@Test
public void toShow() {
ThreadPoolExecutor executor = new ThreadPoolExecutor(
6, 10, 5, TimeUnit.SECONDS, new SynchronousQueue<>()
);
executor.execute(()->{
System.out.println(goodsDao.selectByOutTradeNo("1").toString());
});
executor.execute(()->{
System.out.println(goodsDao.selectByOutTradeNo("2").toString());
});
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

我上面这段代码输出结果为
Goods{outTradeNo='2', totalAmount='null'}
Goods{outTradeNo='1', totalAmount='null'}

然后你在上边打断点是可以进入方法的,看你的代码块,我觉得问题可能出在你进行多线程查询数据库的时候,这个查询过程是需要时间的,而你主程序本身也是一个线程,当主程序线程结束,就代表你代码执行结束,所以你在主程序加上个延长主程序时间的方法,再测试下看看结果。

查看更多
登录 后发表回答